1. Struts标签中的遍历集合 

创新互联是一家集网站建设,黔西企业网站建设,黔西品牌网站建设,网站定制,黔西网站建设报价,网络营销,网络优化,黔西网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。
< logic:iterate> 的 name 属性指定需要进行遍历的集合对象, 它每次从集合中检索出一个元素, 然后把它放在page 范围内, 并以id 属性指定的字符串来命名这个元素, 例如:
| < % Vector animals = new Vector();
 animals.addElement("Dog");
 animals.addElement("Cat");
 animals.addElement("Bird");
 animals.addElement("Chick");
 request.setAttribute("Animals", animals);
 % >
 < logic:iterate id="element" name="Animals">
 < bean:write name="element">
 
 < /logic:iterate>
 | 
以上代码先定义了一个Vector 类型的集合变量 Animals, 它存放在request 范围内. 接下来 标签在一个循环中遍历Animals 集合(这个集合名就是在标签中的name 属性的值)中所有元素, 每次检索到一个元素, 就把它命名为"element"(标签id 属性的值), 并存放在page 范围内. 
在 中, 还嵌套了一个 标签, 它用于输出每个元素的内容. 以上代码的输出内容如下:
 Dog 
Cat 
Bird 
Chick
length 属性指定需要遍历的元素的数目, 如果没有设置length 属性, 就遍历集合中的所有元素.
offset 属性指定开始遍历的起始位置, 默认值为 "0" , 表示从集合的***个元素开始遍历.
indexId 属性定义一个代表当前遍历元素序号的变量, 这个变量被存放在 page 范围内, 可以被标签主体的 标签访问. 例如:
| < ?xml:namespace prefix = logic />< logic:iterate id="element" // 指定输出元素的名 与 < bean:write> 中name 属性一致
 indexId="index" // 遍历元素序号的变量, 这个变量放在page 范围内
 name="Animals" // request 中的集合名, 从中取循环取出元素
 offset="1" // 从集合的第 2 条记录开始取数
 length="2"> // 取出 2 个元素
 < ?xml:namespace prefix = bean />< bean:write name="index">
 < /bean:write>. // 输出每个元素的序号, 与indexId 的属性一致 < bean:write name="element">< /bean:write>
 // 输出每个元素的内容, 与id 的属性一致
 < /logic:iterate>
 | 
2. 遍历Map
 标签还可以遍历HashMap 中的元素, 例如:
| < % HashMap months = new HashMap();
 months.put("Jan","January"); months.put("Feb","February");
 months.put("Mar","March");
 request.setAttribute("month", months); %>
 < logic:iterate id=element name="months" indexId="ind">
 < bean:write name="ind">< /bean:write>. // 序号
 < bean:write name="element" property="key">: // 键名
 < bean:write name="element" property="value">< /bean:write> // 键值
 < /logic:iterate>
 | 
以上代码先定义一个名为"months" 的HashMap, 存放在request 范围内. 接下来在 标签遍历months 对象的每一个元素, 每一个元素包含一对 key/value . 在 标签主体中包含三个 标签, 分别输出每个元素的序号、key 和 value. 以上代码的输出内容如下:
0.Mar: March
1.Feb: February
2.Jan: January
如果HashMap 中的每个元素的 value 是集合对象, 则可以采用嵌套的 标签遍历集合中的所有对象, 例如:
| < % HashMap h = new HashMap();
 String vegetables[] = {"pepper","cucumber"};
 String fruits[] = {"apple","orange","banana","cherry","watermelon"};
 String flowers[] = {"chrysanthemum","rose"};
 String trees[] = {"willow"};
 h.put("Vegetables", vegetables); h.put("Fruits",fruits);
 h.put("Flowers",flowers);
 h.put("Trees",trees);
 request.setAttribute("catalog",h); %>
 < logic:iterate id=element 与< bean:write> 中的name 属性对应, 输出内容
 indexId="ind" // 与
      
        中的name 属性对应, 输出序号
 name="catelog"> // 指定输出元素的名称
 . // 输出序号
 中id 属性对应
 property="key"/> // 集合中的键名
 id="elementValue" // 与< bean:write> 中的name 属性对应
 name="element" // 指定输出元素的名称
 property="value" // 集合中的键值
 length="3" // 取3 个元素
 offset="1"> // 从第 2 个位置取
 -------
 < /logic:iterate>
 < /logic:iterate>
 | 
以上代码先定义一个名为"catelog" 的HashMap , 存放在request 范围内, 它的每个元素的value 为字符串数组. 
接下来外层的 标签遍历HashMap 中的所有元素, 内层的 标签访问每个元素的value 属性, 遍历value 属性引用的字符串数组中的所有元素.
3.设置被遍历的变量 
可以通过以下方式来设置需要遍历的变量
(1) 设置name 属性, name 属性指定需要遍历的集合或Map, 例如:
| < logic:iterate id=element name="Animals"> < /bean:write>
 < /logic:iterate>
 | 
(2) 设置name 属性和property 属性, name 属性指定一个JavaBean, property 属性指定JavaBean 的一个属性, 这个属性为需要遍历的集合或Map, 例如:
| < logic:iterate id=element name="catelog" indexId="ind"> < bean:write name="ind">< /bean:write>
 < bean:write name="element" property="key">< /bean:write>
 < logic:iterate id=elementValue name="element" property="value" offset="1" length="3">
 --------
     
      < /bean:write>
 < /logic:iterate>
 < /logic:iterate>
 | 
(3) 设置collection 属性, collection 属性指定一个运行时表达式, 表达式的运算结果为需要遍历的集合或Map, 例如:
| < logic:iterate id=header collection?<%="request.getHeaderNames()%">"> < bean:write name="header">< /bean:write>
 < /logic:iterate>
 | 
                
                网页名称:浅谈Struts标签logic:iterate                
                标题网址:
http://jxruijie.cn/article/cogogco.html