jsp中的c:foreach基本用法__js

來源:互聯網
上載者:User
在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>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.