详解Struts2标签遍历
作者:lufeng66
struts2的s:iterator 可以遍历 数据栈里面的任何数组,集合等等 以下几个简单的demo:
s:iterator 标签有3个属性:
value:被迭代的集合
id :指定集合里面的元素的id,可以和var属性替换
status 迭代元素的索引
1:jsp页面定义元素写法数组或list
<s:iterator value="{'1','2','3','4','5'}" id='n'> <s:property value='n'/>A </s:iterator>
打印结果为: 1A2A3A4A5A
2:索引的用法
如果指定了status,每次的迭代数据都有IteratorStatus的实例,它有以下几个方法
int getCount()返回当前迭代了几个元素
int getIndex()返回当前元素索引
boolean isEven()当然的索引是否偶数
boolean isFirst()当前是否第一个元素
boolean isLast()
boolean isOdd()当前元素索引是否奇数
<s:iterator value="{'a','b','c'}" id='char' status='st'>
<s:if test="#st.Even">
现在的索引是奇数为:<s:property value='#st.index'/>
</s:if>
当前元素值:<s:property value='char'/>
</s:iterator>
3:遍历map
value可以直接定义为:
value="#{"1":"a","2":"b"}"
每个元素以都好隔开。元素之间的key和value 冒号隔开
value也可以是数据栈里面的java.util.Map对象
遍历写法如下:
<s:iterator value="map" id="id" status="st"> key : <s:property value='key'/> value:<s:property vlaue='value'/> </s:iterator>
当然key 和value 都可以使java 的 Object
4:遍历数据栈.简单的List类
<s:iterator value="data.datas" var="student" status="st"> <tr align="center"> <td> <s:property value="#student.id" /> </td> <td> <s:property value="#student.name" /> </td> <td> <s:date name="#student.birth" fomart="yyyy/MM/dd hh:mm:ss"/> </td> </tr> </s:iterator>
5:遍历2个list
第一个例子
List<AttrName> attrN {color,size,style} List<AttrValue> attrV {red,20,gay}
这2个list的元素是一一对应的,一个attrN对应一个attrV
<s:iterator value="%{attrN }" id="id" status="status"> index is : <s:property value='status.index'/> attrName is : <s:property value='id'/> or <s:property value='%{id}'/> attrName is : <s:property value='%{attrV[#status.index]}'/>
第二个例子
<s:iterator value="data.datas" var="student" status="st"> <tr align="center"> <td> <s:property value="#student.id" /> </td> <td> <s:property value="#student.name" /> </td> <td> <s:date value="#student.birth" fomart="yyyy/MM/dd hh:mm:ss"/> </td> <td> <s:date value="classlist[#st.index].classname"/> </td> </tr> </s:iterator> </s:iterator>
总结
以上就是本文关于详解Struts2标签遍历的全部内容,希望对大家有所帮助,感兴趣的朋友可以参阅:Struts2截取字符串代码介绍 Struts和servlet不能共存问题解决方法 Struts2修改上传文件大小限制方法解析 等,欢迎大家浏览本站其他相关专题。