1. 程式人生 > >關於c:forEach用法詳解

關於c:forEach用法詳解

轉載於:http://blog.csdn.net/honey_claire/article/details/7664165

在JSP的開發中,迭代是經常要使用到的操作。例如,逐行的顯示查詢的結果等。在早期的JSP中,通常使用Scriptlets來實現Iterator或者Enumeration物件的迭代輸出。現在,通過JSTL的迭代標籤可以在很大的程度上簡化迭代操作。

         JSTL所支援的迭代標籤有兩個,分別是<c:forEach>和<c:forTokens>。在這裡介紹的是<c:forEach>標籤。

         簡單點說,<c:forEach>標籤的作用就是迭代輸出標籤內部的內容。它既可以進行固定次數的迭代輸出,也可以依據集合中物件的個數來決定迭代的次數。

         <c:forEach>標籤,需要與el表示式聯合使用

         <c:forEach>標籤的語法定義如下所示。

                  <c:forEach var="每個變數名字"   items="要迭代的list"   varStatus="每個物件的狀態"

                           begin="迴圈從哪兒開始"    end="迴圈到哪兒結束"    step="迴圈的步長">

 迴圈要輸出的東西

                  </c:forEach>

         <
c:forEach>標籤具有以下一些屬性:

l          var:迭代引數的名稱。在迭代體中可以使用的變數的名稱,用來表示每一個迭代變數。型別為String。 

l          items:要進行迭代的集合。對於它所支援的型別將在下面進行講解。 

l          varStatus:迭代變數的名稱,用來表示迭代的狀態,可以訪問到迭代自身的資訊。 

l          begin:如果指定了items,那麼迭代就從items[begin]開始進行迭代;如果沒有指定items,那麼就從begin開始迭代。它的型別為整數。

l          end:如果指定了items,那麼就在items[
end]結束迭代;如果沒有指定items,那麼就在end結束迭代。它的型別也為整數。

l          step:迭代的步長。 

         <c:forEach>標籤的items屬性支援Java平臺所提供的所有標準集合型別。此外,您可以使用該操作來迭代陣列(包括基本型別陣列)中的元素。它所支援的集合型別以及迭代的元素如下所示:

l          java.util.Collection:呼叫iterator()來獲得的元素。 

l          java.util.Map:通過java.util.Map.Entry所獲得的例項。 

l          java.util.Iterator:迭代器元素。 

l          java.util.Enumeration:列舉元素。 

l          Object例項陣列:陣列元素。 

l          基本型別值陣列:經過包裝的陣列元素。 

l          用逗號定界的String:分割後的子字串。 

l          javax.servlet.jsp.jstl.sql.Result:SQL查詢所獲得的行。 

         不論是對整數還是對集合進行迭代,<c:forEach>的varStatus屬性所起的作用相同。和var屬性一樣,varStatus用於建立限定了作用域的變數(改變數只在當前標籤體內起作用)。不過,由varStatus屬性命名的變數並不儲存當前索引值或當前元素,而是賦予javax.servlet.jsp.jstl.core.LoopTagStatus類的例項。該類包含了一系列的特性,它們描述了迭代的當前狀態,如下這些屬性的含義如下所示:

l          current:當前這次迭代的(集合中的)項。 

l          index:當前這次迭代從0開始的迭代索引。 

l          count:當前這次迭代從1開始的迭代計數。 

l          first:用來表明當前這輪迭代是否為第一次迭代,該屬性為boolean型別。 

l          last:用來表明當前這輪迭代是否為最後一次迭代,該屬性為boolean型別。 

l          begin:begin屬性的值。 

l          endend屬性的值 

l          step:step屬性的值 

下面就來看兩個基本的例子,第一個例子是依次輸出集合內的元素。 
<c:forEach var="item" items="${contents}" varStatus="status">
         $status.count:${item} 
</c:forEach
下面的例子是一個固定次數的迭代,用來輸出1到9的平方。 
<c:forEach var="x" begin="1"end="9" step="1">
         ${x*x} 

</c:forEach>

下面寫一下,我做的專案中用到的例子:

分頁:

     <table>
       <tr><th>名字</th><th>說明</th><th>圖片預覽</th></tr>
        <c:forEach items="${data}" var="item">
            <tr><td>${item.advertName}</td><td>${item.notes}</td><td><img src="${item.defPath}"/></td></tr>
        </c:forEach>

     </table>
    <ul>
        <li><a href='?nowPage=${nowPage-1}'>←上一頁</a></li>
                   <c:forEach varStatus="i" begin="1" end="${sumPage}">
                        <c:choose>
                           <c:when test="${nowPage==i.count}">
                              <li class='disabled'>${i.count}</li>
                           </c:when>
                           <c:otherwise>
                               <li  class='active'><a href='?nowPage=${i.count}'>${i.count}</a></li>
                           </c:otherwise>
                        </c:choose>
                   </c:forEach>

            <li><a href='?nowPage=${nowPage+1}'>下一頁→</a></li>
      </ul>

首頁展示圖片的例子:

迭代後臺傳過來的list, src的路徑要寫絕對路徑,寫成相對路徑會報錯,有時絕對路徑用<c:ulr>來寫

           <c:forEach items="${lists}" var="item">
             <img id="img${i}" height="250" width="500"  class="img" src='UploadImages/${item.advertPath}'/>
            </c:forEach>

獲得下標,其中size是後臺傳過來的list的長度,此處不能寫成end="${list.size}"

              <c:forEach begin="1" end="${size}"  step="1" varStatus="i">
                    <li> <a href="http://www.baidu.com/" class="showimg">${i.index}</a></li>
                 </c:forEach>