<c:forEach>标签与el表达式联合的使用

  1. <span style="font-size:24px;color:#ff0000;"><strong><c:foreach>常用的用法</strong></span><span style="color: rgb(51, 51, 51); font-size: 14px;">  
  2. 转的,可以用来作为自己的学习笔记  
  3. <c:foreach>类似于for和foreach循环   以下是我目前见过的用法:   
  4. 1、循环遍历,输出所有的元素。   
  5. <c:foreach items="${list}" var="li">   
  6. ${li}   
  7. </c:foreach>   
  8. 注意:items 用于接收集合对象,var 定义对象接收从集合里遍历出的每一个元素。同时其会自动转型。   
  9. 2、循环遍历,输出一个范围类的元素。   
  10. <c:foreach items ="${lis}" var = "li " begin="2" end ="12">   
  11. ${li}   
  12. </c:foreach>   
  13. 注意:begin 定义遍历的开始位置,end定义遍历的结束位置。begin 和end的引号必须写。   
  14. 3、循环遍历,输出除某个元素以外的元素或输出指定元素。   
  15. <c:foreach items="${list}" var ="li" varStatus="status">   
  16. <c:if text="${status.count==1}>   
  17. ${"第一个元素不要"}   
  18. </c:if>   
  19. ${li}   
  20. </ c:foreach>   
  21. 注意:varStatus 表示当前集合的状态(其实是不是,我也不太清楚,只知道这样用,会的人指点下),count为循环一个计算器。   
  22. 4、循环遍历,输出第一个或最后一个元素。   
  23. <c:foreach items="${list}" var ="li" varStatus="status">   
  24. <c:if test="${status.first}">我是第一个元素</c:if>   
  25. <c:if test="${status.last}">我是最后一个元素</c:if>   
  26. </c:foreach>   
  27. 注意:first表示如果是一个元素,则返回ture,反之则返回false   
  28.            last 表示如果是最后一个元素,则返回ture,反之则返回false。  
  29. 5、循环遍历,按指定步长输出。  
  30. <c:foreach items="list" var ="li" step="2">  
  31. ${li}  
  32. </c:foreach>  
  33. 注意:step为循环的步长。每次隔两个单位输出一个。如:1、3、5、==</span>  

[html]  view plain  copy
  1. <span style="font-size:24px;color:#ff0000;"><strong><c:foreach>详细的用法</strong></span>  


[html]  view plain  copy
  1. 在JSP的开发中,迭代是经常要使用到的操作。例如,逐行的显示查询的结果等。在早期的JSP中,通常使用Scriptlets来实现Iterator或者Enumeration对象的迭代输出。现在,通过JSTL的迭代标签可以在很大的程度上简化迭代操作。  
  2.          JSTL所支持的迭代标签有两个,分别是<c:forEach><c:forTokens>。在这里介绍的是<c:forEach>标签。  
  3.          简单点说,<c:forEach>标签的作用就是迭代输出标签内部的内容。它既可以进行固定次数的迭代输出,也可以依据集合中对象的个数来决定迭代的次数。  
  4.          <c:forEach>标签,需要与el表达式联合使用  
  5.          <c:forEach>标签的语法定义如下所示。  
  6.   
  7.                   <c:forEach var="每个变量名字"   items="要迭代的list"   varStatus="每个对象的状态"  
  8.   
  9.                            begin="循环从哪儿开始"    end="循环到哪儿结束"    step="循环的步长">  
  10.   
  11.                               循环要输出的东西  
  12.   
  13.                   </c:forEach>  
  14.   
  15.          <c:forEach>标签具有以下一些属性:  
  16.   
  17. l          var:迭代参数的名称。在迭代体中可以使用的变量的名称,用来表示每一个迭代变量。类型为String。   
  18.   
  19. l          items:要进行迭代的集合。对于它所支持的类型将在下面进行讲解。   
  20.   
  21. l          varStatus:迭代变量的名称,用来表示迭代的状态,可以访问到迭代自身的信息。   
  22.   
  23. l          begin:如果指定了items,那么迭代就从items[begin]开始进行迭代;如果没有指定items,那么就从begin开始迭代。它的类型为整数。  
  24.   
  25. l          end:如果指定了items,那么就在items[end]结束迭代;如果没有指定items,那么就在end结束迭代。它的类型也为整数。  
  26.   
  27. l          step:迭代的步长。   
  28.   
  29.          <c:forEach>标签的items属性支持Java平台所提供的所有标准集合类型。此外,您可以使用该操作来迭代数组(包括基本类型数组)中的元素。它所支持的集合类型以及迭代的元素如下所示:  
  30.   
  31. l          java.util.Collection:调用iterator()来获得的元素。   
  32.   
  33. l          java.util.Map:通过java.util.Map.Entry所获得的实例。   
  34.   
  35. l          java.util.Iterator:迭代器元素。   
  36.   
  37. l          java.util.Enumeration:枚举元素。   
  38.   
  39. l          Object实例数组:数组元素。   
  40.   
  41. l          基本类型值数组:经过包装的数组元素。   
  42.   
  43. l          用逗号定界的String:分割后的子字符串。   
  44.   
  45. l          javax.servlet.jsp.jstl.sql.Result:SQL查询所获得的行。   
  46.   
  47.          不论是对整数还是对集合进行迭代,<c:forEach>的varStatus属性所起的作用相同。和var属性一样,varStatus用于创建限定了作用域的变量(改变量只在当前标签体内起作用)。不过,由varStatus属性命名的变量并不存储当前索引值或当前元素,而是赋予javax.servlet.jsp.jstl.core.LoopTagStatus类的实例。该类包含了一系列的特性,它们描述了迭代的当前状态,如下这些属性的含义如下所示:  
  48.   
  49. l          current:当前这次迭代的(集合中的)项。   
  50.   
  51. l          index:当前这次迭代从0开始的迭代索引。   
  52.   
  53. l          count:当前这次迭代从1开始的迭代计数。   
  54.   
  55. l          first:用来表明当前这轮迭代是否为第一次迭代,该属性为boolean类型。   
  56.   
  57. l          last:用来表明当前这轮迭代是否为最后一次迭代,该属性为boolean类型。   
  58.   
  59. l          begin:begin属性的值。   
  60.   
  61. l          end:end属性的值   
  62.   
  63. l          step:step属性的值   
  64.   
  65. 下面就来看两个基本的例子,第一个例子是依次输出集合内的元素。   
  66. <c:forEach var="item" items="${contents}" varStatus="status">  
  67.          $status.count:${item}   
  68. </c:forEach>   
  69. 下面的例子是一个固定次数的迭代,用来输出1到9的平方。   
  70. <c:forEach var="x" begin="1"end="9" step="1">   
  71.          ${x*x}   
  72. </c:forEach>  
  73. 下面写一下,我做的项目中用到的例子:  
  74. 分页:  
  75.      <table>  
  76.        <tr><th>名字</th><th>说明</th><th>图片预览</th></tr>  
  77.         <c:forEach items="${data}" var="item">  
  78.             <tr><td>${item.advertName}</td><td>${item.notes}</td><td><img src="${item.defPath}"/></td></tr>  
  79.         </c:forEach>  
  80.      </table>  
  81.     <ul>  
  82.         <li><a href='?nowPage=${nowPage-1}'>←上一页</a></li>  
  83.                    <c:forEach varStatus="i" begin="1" end="${sumPage}">  
  84.                         <c:choose>  
  85.                            <c:when test="${nowPage==i.count}">  
  86.                               <li class='disabled'>${i.count}</li>  
  87.                            </c:when>  
  88.                            <c:otherwise>  
  89.                                <li  class='active'><a href='?nowPage=${i.count}'>${i.count}</a></li>  
  90.                            </c:otherwise>  
  91.                         </c:choose>  
  92.                    </c:forEach>  
  93.             <li><a href='?nowPage=${nowPage+1}'>下一页→</a></li>  
  94.       </ul>  
  95. 首页展示图片的例子:  
  96. 迭代后台传过来的list, src的路径要写绝对路径,写成相对路径会报错,有时绝对路径用<c:ulr>来写  
  97.            <c:forEach items="${lists}" var="item">  
  98.              <img id="img${i}" height="250" width="500"  class="img" src='UploadImages/${item.advertPath}'/>  
  99.             </c:forEach>  
  100. 获得下标,其中size是后台传过来的list的长度,此处不能写成end="${list.size}"  
  101.               <c:forEach begin="1" end="${size}"  step="1" varStatus="i">  
  102.                     <li> <a href="http://www.baidu.com/" class="showimg">${i.index}</a></li>  
  103.                  </c:forEach>  
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值