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>
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值