巧用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>