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>
经验分享 程序员 微信小程序 职场和发展