上周在工作中遇到了页面迭代的情况,初来乍到只知道简单的迭代用法,但是我要处理的情况是一个List A 需要每18条数据去一个迭代成行 每六条数据在每行中迭代出三列 再把每条数据放在这三列中形成六个点。听上去有些乱啊!确实挺头疼的,呵呵
这样可能看的就清晰些了。
先简单说一下<c: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:迭代的步长。
<c:forEach>标签的items属性支持Java平台所提供的所有标准集合类型。此外,您可以使用该操作来迭代数组(包括基本类型数组)中的元素。它所支持的集合类型以及迭代的元素如下所示:
java.util.Collection:调用iterator()来获得的元素。
java.util.Map:通过java.util.Map.Entry所获得的实例。
java.util.Iterator:迭代器元素。
java.util.Enumeration:枚举元素。
Object实例数组:数组元素。
基本类型值数组:经过包装的数组元素。
用逗号定界的String:分割后的子字符串。
javax.servlet.jsp.jstl.sql.Result:SQL查询所获得的行。
不论是对整数还是对集合进行迭代,<c:forEach>的varStatus属性所起的作用相同。和var属性一样,varStatus用于创建限定了作用域的变量(改变量只在当前标签体内起作用)。不过,由varStatus属性命名的变量并不存储当前索引值或当前元素,而是赋予javax.servlet.jsp.jstl.core.LoopTagStatus类的实例。该类包含了一系列的特性,它们描述了迭代的当前状态,如下这些属性的含义如下所示:
current:当前这次迭代的(集合中的)项。
index:当前这次迭代从0开始的迭代索引。
count:当前这次迭代从1开始的迭代计数。
first:用来表明当前这轮迭代是否为第一次迭代,该属性为boolean类型。
last:用来表明当前这轮迭代是否为最后一次迭代,该属性为boolean类型。
begin:begin属性的值。
end:end属性的值
step:step属性的值
下面就来看两个基本的例子,第一个例子是依次输出集合内的元素。
<c:forEach var="item" items="${contents}" varStatus="status">
$status.count:${item}
</c:forEach>
下面的例子是一个固定次数的迭代,用来输出1到9的平方。
<c:forEach var="x" begin="1" end="9" step="1">
${x*x}
</c:forEach>
(以上这个介绍转自:http://www.blogjava.net/caizh2009/articles/278999.html)
好了,现在说说我的问题
很显然我遇到的问题,需要嵌套迭代。说实话,如果是用for去实现这个,在我看来还是很简单的。但是在jsp中植入脚本语言不是很正规(主要是领导不让),所以只好迭代。
与forEach与for的区别最主要是没有i++这个操作,所以用起来不太一样。forEach提供了index属性可以帮我们解决这个问题。当使用for时,最里层的for循环中获取的时间复杂度也就是循环次数为每层for循环的次数相乘 而在forEach中,我们只能利用index属性在最里层进行认为计算。在每层也要规定它的循环次数,才能最终获得指定的数据。似乎我的表达能力有限,可能说的不是很明白。不过没关系,有代码有真相~~~
1 <c:forEach var="data"items="${statusSource}" begin="1" step="18" varStatus="st1" > 2 <tr class="multicolor1" > 3 <c:forEach var="td" begin="1" end="6" varStatus="st2"> 4 <td style="TEXT-ALIGN: center;"> 5 <c:forEach begin="1" end="3" var="subcol" varStatus="st3"> 6 7 ${statusSource[(st1.index-1)+(st2.index-1)*6+(st3.index)-1]} 8 9 </c:forEach> 10 </td> 11 </c:forEach> 12 </tr> 13 </c:forEach>
学习了~~