在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 end : end 屬性的值
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>