jsp中c:forEach的⽤法
在JSP的开发中,迭代是经常要使⽤到的操作。例如,逐⾏的显⽰查询的结果等。在早期的JSP中,通常使⽤Scriptlets来实现Iterator或者Enumeration对象的迭代输出。现在,通过JSTL的迭代标签可以在很⼤的程度上简化迭代操作。
使⽤像<s:  <c:这类标签时,jsp页⾯必须导⼊对于的库,如下:
JSTL所⽀持的迭代标签有两个,分别是<c:forEach>和<c:forTokens>。在这⾥介绍的是<c:forEach>标签。
简单点说,<c:forEach>标签的作⽤就是迭代输出标签内部的内容。它既可以进⾏固定次数的迭代输出,也可以依据集合中对象的个数来决定迭代的次数。
<c:forEach>标签,需要与el表达式联合使⽤
<c:forEach>标签的语法定义如下所⽰。
<c:forEach var="每个变量名字"  items="要迭代的list"  varStatus="每个对象的状态"
begin="循环从哪⼉开始"    end="循环到哪⼉结束"    step="循环的步长">
循环要输出的东西
</c:forEach>
<c:forEach>标签具有以下⼀些属性:
l          var:迭代参数的名称。在迭代体中可以使⽤的变量的名称,⽤来表⽰每⼀个迭代变量。类型为String。
l          items:要进⾏迭代的集合。对于它所⽀持的类型将在下⾯进⾏讲解。
l          varStatus:迭代变量的名称,⽤来表⽰迭代的状态,可以访问到迭代⾃⾝的信息。
l          begin:如果指定了items,那么迭代就从items[begin]开始进⾏迭代;如果没有指定items,那么就从begin开始迭代。它的类型为整数。
l          end:如果指定了items,那么就在items[end]结束迭代;如果没有指定items,那么就在end结束迭代。它的类型也为整数。
l          step:迭代的步长。
<c:forEach>标签的items属性⽀持Java平台所提供的所有标准集合类型。此外,您可以使⽤该操作来迭代数组(包括基本类型数组)中的元素。它所⽀持的集合类型以及迭代的元素如下所⽰:
l          java.util.Collection:调⽤iterator()来获得的元素。
l          java.util.Map:通过java.util.Map.Entry所获得的实例。
l          java.util.Iterator:迭代器元素。
l          java.util.Enumeration:枚举元素。
l          Object实例数组:数组元素。
l          基本类型值数组:经过包装的数组元素。c++中string的用法
l          ⽤逗号定界的String:分割后的⼦字符串。
l          javax.servlet.jsp.jstl.sql.Result:SQL查询所获得的⾏。
不论是对整数还是对集合进⾏迭代,<c:forEach>的varStatus属性所起的作⽤相同。和var属性⼀样,varStatus⽤于创建限定了作⽤域的变量(改变量只在当前标签体内起作⽤)。不过,由varStatus属性
命名的变量并不存储当前索引值或当前元素,⽽是赋予javax.servlet.LoopTagStatus类的实例。该类包含了⼀系列的特性,它们描述了迭代的当前状态,如下这些属性的含义如下所⽰:
l          current:当前这次迭代的(集合中的)项。
l          index:当前这次迭代从0开始的迭代索引。
l          count:当前这次迭代从1开始的迭代计数。
l          first:⽤来表明当前这轮迭代是否为第⼀次迭代,该属性为boolean类型。
l          last:⽤来表明当前这轮迭代是否为最后⼀次迭代,该属性为boolean类型。
l          begin:begin属性的值。
l          end:end属性的值
l          step:step属性的值
下⾯就来看两个基本的例⼦,第⼀个例⼦是依次输出集合内的元素。
<c:forEach var="item" items="${contents}" varStatus="status">
$unt:${item}
</c:forEach>
下⾯的例⼦是⼀个固定次数的迭代,⽤来输出1到9的平⽅。
<c:forEach var="x" begin="1"end="9" step="1">
${x*x}
</c:forEach>
下⾯写⼀下,我做的项⽬中⽤到的例⼦:
分页:
<table>
<tr><th>名字</th><th>说明</th><th>图⽚预览</th></tr>
<c:forEach items="${data}" var="item">
<tr><td>${item.advertName}</td><td>${s}</td><td><img src="${item.defPath}"/></td></tr>
</c:forEach>
</table>
<ul>
<li><a href='?nowPage=${nowPage-1}'>←上⼀页</a></li>
<c:forEach varStatus="i" begin="1" end="${sumPage}">
<c:choose>
<c:when test="${nowPage==i.count}">
<li class='disabled'>${i.count}</li>
</c:when>
<c:otherwise>
<li  class='active'><a href='?nowPage=${i.count}'>${i.count}</a></li>
</c:otherwise>
</c:choose>
</c:forEach>
<li><a href='?nowPage=${nowPage+1}'>下⼀页→</a></li>
</ul>
⾸页展⽰图⽚的例⼦:
迭代后台传过来的list, src的路径要写绝对路径,写成相对路径会报错,有时绝对路径⽤<c:ulr>来写
<c:forEach items="${lists}" var="item">
<img id="img${i}" height="250" width="500"  class="img" src='UploadImages/${item.advertPath}'/>            </c:forEach>
获得下标,其中size是后台传过来的list的长度,此处不能写成end="${list.size}"
<c:forEach begin="1" end="${size}"  step="1" varStatus="i">
<li> <a href="www.baidu/" class="showimg">${i.index}</a></li>
</c:forEach>
下⾯完整例⼦:
思路:在进⼊本页⾯的接⼝中,写⼊下⾯该⽅法(对象需写在action类⾥,不能写在⽅法中)
后台端:
public String getArticleAll() {
list = (List<Article>) bo.listAll(Article.class);
//设置进去,以便前台通过list参数接收
request.setAttribute("list",list);
result.setSuccess(true);
return Action.SUCCESS;
}
jsp页⾯这样接收:
<ul>
<c:forEach items="${list}" var="item">
<li>${item.id} ${item.title} ${t}<li>
</c:forEach>
</ul>
==========================================分割线
=====================================================
1、实例源码
35.
2、实例结果31.

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。