JSTL 的forEach标签循环迭代集合并逆序输出
巧用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>