• JSTL的c:forEach标签(${status.index})


    <c:forEach>标签具有以下一些属性: 

                var:迭代参数的名称。在迭代体中可以使用的变量的名称,用来表示每一个迭代变量。类型为String。 

                items:要进行迭代的集合。对于它所支持的类型将在下面进行讲解。 

                varStatus:迭代变量的名称,用来表示迭代的状态,可以访问到迭代自身的信息。 

                begin:如果指定了items,那么迭代就从items[begin]开始进行迭代;如果没有指定items,那么就从begin开始迭代。它的类型为整数。 

                end:如果指定了items,那么就在items[end]结束迭代;如果没有指定items,那么就在end结束迭代。它的类型也为整数。 

                step:迭代的步长。 

              <c:forEach>标签的items属性支持Java平台所提供的所有标准集合类型。此外,您可以使用该操作来迭代数组(包括基本类型数组)中的元素。它所支持的集合类型以及迭代的元素如下所示: 

                java.util.Collection:调用iterator()来获得的元素。 
     
                java.util.Map:通过java.util.Map.Entry所获得的实例。 

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

                java.util.Enumeration:枚举元素。 

                Object实例数组:数组元素。 

                基本类型值数组:经过包装的数组元素。 

                用逗号定界的String:分割后的子字符串。 

                javax.servlet.jsp.jstl.sql.Result:SQL查询所获得的行。 

              不论是对整数还是对集合进行迭代, <c:forEach>的varStatus属性所起的作用相同。和var属性一样,varStatus用于创建限定了作用域的变量(改变量只在当前标签体内起作用)。不过,由varStatus属性命名的变量并不存储当前索引值或当前元素,而是赋予javax.servlet.jsp.jstl.core.LoopTagStatus类的实例。该类包含了一系列的特性,它们描述了迭代的当前状态,如下这些属性的含义如下所示: 

                current:当前这次迭代的(集合中的)项。 

                index:当前这次迭代从0开始的迭代索引。 

                count:当前这次迭代从1开始的迭代计数。 

                first:用来表明当前这轮迭代是否为第一次迭代,该属性为boolean类型。 

                last:用来表明当前这轮迭代是否为最后一次迭代,该属性为boolean类型。 

                begin:begin属性的值。 

                end:end属性的值 

                step:step属性的值 


     
    利用varStatus属性:
    There is a pure way to desplay chekbox with two collums in jsp page.
    checkboxLists是  checkBoxTO的集合,含有key,value,checke属性。
    Java代码
    1. <c:forEach items="${checkboxList}" begin="0" step="2" varStatus="status">   
    2. <tr>   
    3. <td><c:out value="${status.index}"/><input type="checkbox" value='<c:out value="${checkboxList[status.index].key}"/>'   
    4. <c:if test="${checkboxList[status.index].checked eq true}">checked="checked"</c:if>   
    5. /><c:out value="${checkboxList[status.index].value}"/>   
    6. </td>   
    7.     
    8. <td><c:if test="${!empty checkboxList[status.index+1]}"><!--判断是否还有下一个纪录,for奇数-->   
    9. <c:out value="${status.index+1}"/><input type="checkbox" value='<c:out value="${checkboxList[status.index+1].key}"/>'   
    10. <c:if test="${checkboxList[status.index+1].checked eq true}">checked="checked"</c:if>   
    11. /><c:out value="${checkboxList[status.index+1].value}"></c:out>   
    12. </c:if>   
    13. </td>   
    14. </tr>   
    15. </c:forEach>  
  • 相关阅读:
    node异步转同步(循环)
    三级省市区PCASClass.js插件
    微信公众号基础总结(待更新)
    ES6详解
    webpack配置
    高性能 CSS3 动画
    github上传口令
    纯css3 实现3D轮播图
    优美的js代码,拿去玩~
    关于列举属性用点还是用【】
  • 原文地址:https://www.cnblogs.com/wjwen/p/4581660.html
Copyright © 2020-2023  润新知