JSTL 的forEach标签循环迭代集合并逆序输出

来源:互联网 发布:大数据涉及哪些行业 编辑:程序博客网 时间:2024/05/24 20:07

巧用forEach标签对集合进行逆序输出!

  • forEach标签介绍
    <c:forEach>标签的作用就是迭代输出标签内部的内容。它既可以进行固定次数的迭代输出,也可以依据集合中对象的个数来决定迭代的次数。    <c:forEach>标签的语法定义如下所示。             <c:forEach var="name" items="expression" varStatus="name"                      begin="expression" end="expression" step="expression">                      body content             </c:forEach>    <c:forEach>

标签具有以下一些属性:
var:迭代参数的名称。在迭代体中可以使用的变量的名称,用来表示每一个迭代变量。类型为String。
items:要进行迭代的集合。对于它所支持的类型将在下面进行讲解。
varStatus:迭代变量的名称,用来表示迭代的状态,可以访问到迭代自身的信息。
begin:如果指定了items,那么迭代就从items[begin]开始进行迭代;如果没有指定items,那么就从begin开始迭代。它的类型为整数。
end:如果指定了items,那么就在items[end]结束迭代;如果没有指定items,那么就在end结束迭代。它的类型也为整数。
step:迭代的步长。

  • forEach标签使用
<c:set var="goods" value="${order.goods}"/><c:set var="goodsize" value="${fn:length(goods)}"/><c:forEach items="${goods}" varStatus="s">/*这里是对集合进行逆序迭代的关键呀*/<c:set var="good" value="${goods[goodsize- s.index - 1]}"/>   <li class="good-unit">       <div class="good">       <c:if test="${good.status == 4}">          <p>${good.statusName},卖完了呀,明天再来</p>       </c:if>       <c:if test="${good.status != 4}">          <p>${good.statusName}</p>       </c:if>          <p>${good.datetime}</p>       </div>   </li></c:forEach>
0 0
原创粉丝点击