您的位置:首页 > Web前端 > JavaScript

关于jstl标签c:foreach相关属性讲解

2015-06-04 11:00 549 查看
在项目中经常用到c:foreach这个标签,对于c:foreach里面的一些属性可能大部分都已经属性了,但是还有一小部分每次在用的时候,还是免不了再查,尤其是需要知道items中list的长度时,这里都进行了汇总,以方便自己使用。

<c:forEach var="order" items="${page.data}">

<table width="100%" class="user_td">
<tr>
<td><div class="user_w960" >
<b>${order.orderTime }</b>   订单号: ${order.code }    </div></td>
<td colspan="5"><div style="font-weight:bold; float:right; width:150px; font-size:14px;">合计:<b style="color:#FF0000;">${order.totalMoney }</b>元</div></td>
</tr>
<c:forEach var="orderProduct" items="${order.orderProductList}" varStatus="orderProductStatus">
<tr >
<td width="51%" class="usr_p_left"><div class="user_h40"><a href="productToProductDetail?pid=${orderProduct.productId }"><img src="${orderProduct.image }" /></a>
<p><a href="productToProductDetail?pid=${orderProduct.productId }">${orderProduct.name }</a></p>
</div></td>
<td width="7%">${orderProduct.count }</td>
<c:if test="${orderProductStatus.first}">
<td width="8%" rowspan="${fn:length(order.orderProductList) }">${order.receiveUserName }</td>
</c:if>
<td width="14%">¥${orderProduct.price }</td>
<c:if test="${orderProductStatus.first}">
<td width="8%" rowspan="${fn:length(order.orderProductList) }">
下单
</td>
</c:if>
<c:if test="${orderProductStatus.first}">
<td width="12%" rowspan="${fn:length(order.orderProductList) }"><a href="#">查看</a><br>
<a href="#">去支付</a>/<a href="#">取消</a>
</td>
</c:if>
</tr>
</c:forEach>
</table>
</c:forEach>


这里获取 items="${order.orderProductList}的长度,通过JSTL的fn函数来获取,${fn:length(order.orderProductList) }

下面讲解下c:foreach的常用属性

<c:forEach>标签具有以下一些属性:
var:迭代参数的名称。在迭代体中可以使用的变量的名称,用来表示每一个迭代变量。类型为String。
items:要进行迭代的集合。对于它所支持的类型将在下面进行讲解。
varStatus:迭代变量的名称,用来表示迭代的状态,可以访问到迭代自身的信息。
begin:如果指定了items,那么迭代就从items[begin]开始进行迭代;如果没有指定items,那么就从begin开始迭代。它的类型为整数。
end:如果指定了items,那么就在items[end]结束迭代;如果没有指定items,那么就在end结束迭代。它的类型也为整数。
step:迭代的步长。
current:当前这次迭代的(集合中的)项。
index:当前这次迭代从0开始的迭代索引。
count:当前这次迭代从1开始的迭代计数。
first:用来表明当前这轮迭代是否为第一次迭代,该属性为boolean类型。
last:用来表明当前这轮迭代是否为最后一次迭代,该属性为boolean类型。
begin:begin属性的值。
end:end属性的值
step:step属性的值


内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: