20、 (2分)下列哪个JSTL标签可用于遍历集合或数组()? A、<cset> B、<c:forEach> C、<cif> D、<cchoose>
时间: 2023-08-16 16:03:47 浏览: 138
B、<c:forEach>。在JSTL中,<c:forEach>标签用于遍历集合或数组,并对其中的每个元素执行相同的操作。该标签包含三个必需的属性:var、items和begin(可选),以及若干个可选的属性,如end、step、varStatus等。例如:
```jsp
<c:forEach var="item" items="${items}">
<li>${item}</li>
</c:forEach>
```
在上面的例子中,<c:forEach>标签从名为items的属性中获取一个集合或数组,并将其中的每个元素存储在名为item的变量中。然后,对于每个元素,使用${item}表达式输出其值。需要注意的是,<c:forEach>标签可以嵌套使用,以实现更复杂的遍历操作。
需要说明的是,<c:set>标签用于设置一个变量的值,而不是遍历集合或数组。<c:if>和<c:choose>标签用于条件判断和分支选择,也不能用于遍历集合或数组。
相关问题
<c:set var="sum_price" value="0"></c:set> <!-- 定义一个变量来存储商品数量 --> <c:set var="goods_count" value="0"></c:set> <!-- 定义一个变量来存储,购物车的id集合 --> <c:set var="tids" value="#"></c:set> <c:forEach items="${trolleys }" var="trolley"> <c:set var="tids" value="${tids }#${trolley.tid }"></c:set> <div class="tro_tab_h1"> <div class="col tro_tab_check"> <span class="tro_tab_check_sp"></span> </div> <div class="col tro_tab_img"> <img src="<%=imgPath %>${trolley.goods.pic }" alt=""> </div> <div class="col tro_tab_name"> <li class="tro_tab_name_li1" style="font-size: 16px;">${trolley.goods.gname } ${trolley.goods.color }</li> </div> <div class="col tro_tab_price"> <span id="price">${trolley.goods.price }</span><span>元</span> </div> <div class="col tro_tab_num"> <a class="tro_tab_num_p1" id="subtract" href="javascript:void(0)" onclick="addOrDeleteNumber(${trolley.tid}, ${trolley.number - 1 })">-</a> <input type="text" value="${trolley.number }" id="num"> <c:set var="goods_count" value="${goods_count + trolley.number }"></c:set> <a class="tro_tab_num_p2" id="plus" href="javascript:void(0)" onclick="addOrDeleteNumber(${trolley.tid}, ${trolley.number + 1 })">+</a> </div> <div class="col tro_tab_total "> <c:set var="sum_price" value="${sum_price + trolley.goods.price * trolley.number }"></c:set> <span class="tro_tab_total_value" id="prices" >${trolley.goods.price * trolley.number }</span>元 </div> <div class="col tro_tab_action" style="cursor: pointer;width: 40px;height: 40px;" onclick="deleteTrolley(${trolley.tid })">删除</div> </div> </c:forEach>
这是一个JSP页面中的JSTL标签,它的作用是遍历一个名为"trolleys"的集合,对于集合中的每一个元素,都生成一段HTML代码,用于展示该商品在购物车中的相关信息。在遍历过程中,该标签还声明了三个变量,分别是"sum_price"、"goods_count"和"tids"。其中,"sum_price"变量的初始值为0,用于累加购物车中所有商品的总价;"goods_count"变量的初始值为0,用于累加购物车中所有商品的数量;"tids"变量的初始值为"#",用于存储购物车中所有商品的id,以"#"分隔开。在遍历完成后,这三个变量的最终值分别为购物车中所有商品的总价、数量和id集合。
具体的HTML代码中,每个商品的信息都被包含在一个class为"tro_tab_h1"的div标签中,该标签包含了商品的选择框、商品图片、商品名称、商品价格、商品数量、商品总价和删除按钮等元素。在展示每个商品的价格、数量和总价时,该标签还使用了上述三个变量的值。同时,商品数量可以通过点击"+"或"-"按钮来增减,每次增减数量时,都会调用一个名为"addOrDeleteNumber"的JavaScript函数来更新购物车中该商品的数量。删除按钮被点击时,会调用名为"deleteTrolley"的JavaScript函数来从购物车中删除该商品。
阅读全文