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

在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>

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章