zoukankan      html  css  js  c++  java
  • iterator的用法

    1. 转自:http://alvinqq.iteye.com/blog/579821
    2. 在说明s:iterator标签的使用前,先了解下struts2中的Value Stack。这里参考了webwork中对Value Stack的描述,由于struts2是在webwork的基础上进行升级的,因此webwork对于Value Stack的表述同样适用于struts2。在这里不描述Value Stack具体做什么,但有两点需要注意: 
    3. 一个value stack本质上是一个List;  
    4. 在栈中调用[n]将返回一个从位置n开始的子栈;  
    5. 对于2举个例子说明。假定Value Stack包含了[model,action,others],那么 
    6. [0] --- 返回 [model,action,others];  
    7. [1] --- 返回 [action,others];  
    8. [2] --- 返回 [others];  
    9. 现在将开始介绍s:iterator的一些使用。以下代码片段均在开发环境eclipse3.4 wtp、tomcat5.5、jdk5上使用struts2.1.6测试通过。 
    10. 1) 、访问 days  
    11. defined  List<String>  days   ["Monday","Thursday","Friday","Sunday"]  
    12. view plaincopy to clipboardprint? 
    13. <s:iterator value="days"><s:property /></s:iterator>   
    14. <s:iterator value="days"><s:property /></s:iterator>  
    15. 2) 、使用 top 关键字使用(过滤掉Monday)  
    16. defined  List<String>  days   ["Monday","Thursday","Friday","Sunday"]  
    17. view plaincopy to clipboardprint? 
    18. <s:iterator value="days">   
    19.             <s:if test="top!='Monday'">   
    20.                 <s:property />   
    21.             </s:if>   
    22.         </s:iterator>   
    23. <s:iterator value="days"> 
    24.             <s:if test="top!='Monday'"> 
    25.                 <s:property /> 
    26.             </s:if> 
    27.         </s:iterator>  
    28. top 指代当前迭代元素,可以为对象;  
    29. 这里的top可用[0].top替代,但不能使用[0]。[0]代表整个栈对象。如果单纯调用[0]将会调用其toString()方法输出对象信息; 
    30. 3)、使用 last / first 关键字使用  
    31. defined  String[][] aTs = { { "一", "二", "三", "四" },{ "一一", "二二", "三三", "四四"} };  
    32. view plaincopy to clipboardprint? 
    33. <!--遍历二维数组,The trick here is to use 'top' as the value for the inner iterator-->   
    34.           <s:iterator value="aTs" status="of">   
    35.           <s:if test="#of.last"><br/></s:if>   
    36.           <s:iterator value="top">   
    37. <!--亦可用[0].top替代。如果单纯用[0],则会同时打印该处栈对象信息-->   
    38.          <s:property />   
    39.           </s:iterator>   
    40.           </s:iterator>   
    41. <!--遍历二维数组,The trick here is to use 'top' as the value for the inner iterator--> 
    42.           <s:iterator value="aTs" status="of"> 
    43.        <s:if test="#of.last"><br/></s:if> 
    44.        <s:iterator value="top"> 
    45. <!--亦可用[0].top替代。如果单纯用[0],则会同时打印该处栈对象信息--> 
    46.    <s:property /> 
    47.        </s:iterator> 
    48.           </s:iterator>    
    49. iterator 标签中的status属性代表当前迭代的位置;  
    50. #of.last用于判断当前是否跌到的最后一个元素;  
    51. last返回一个boolean类型;  
    52. first 返回一个boolean类型;  
    53. 4)、使用 odd / even 关键字  
    54. 下面的例子要实现每行输出颜色不同的效果。 
    55. defined  List<String>  days   ["Monday","Thursday","Friday","Sunday"]  
    56. view plaincopy to clipboardprint? 
    57.        <!--奇数行显示为红色,偶数行显示为绿色-->   
    58.        <s:iterator value="days" status="offset">   
    59.     <s:else>   
    60.         <s:if test="#offset.odd==true">   
    61.             <li style="color: red" mce_style="color: red"><s:property /></li>   
    62.         </s:if>   
    63.         <s:else>   
    64.             <li><s:property /></li>   
    65.         </s:else>   
    66.     </s:else>   
    67. </s:iterator>   
    68.         <!--奇数行显示为红色,偶数行显示为绿色--> 
    69.         <s:iterator value="days" status="offset"> 
    70.   <s:else> 
    71.    <s:if test="#offset.odd==true"> 
    72.     <li style="color: red" mce_style="color: red"><s:property /></li> 
    73.    </s:if> 
    74.    <s:else> 
    75.     <li><s:property /></li> 
    76.    </s:else> 
    77.   </s:else> 
    78. </s:iterator>  
    79. odd关键字用来判断当前迭代位置是否为奇数行。odd返回boolean类型;  
    80. evne关键字用来判断当前迭代位置是否为偶数行。even返回boolean类型  
    81. 5)、总结下,当声明iterator的status属性时,通过#statusName.method 可以使用以下方法: 
    82. even : boolean - 如果当前迭代位置是偶数返回true
    83. odd : boolean - 如果当前迭代位置是奇数返回true
    84. count : int - 返回当前迭代位置的计数(从1开始)  
    85. index : int - 返回当前迭代位置的编号(从0开始)  
    86. first : boolean - 如果当前迭代位置是第一位时返回true
    87. last : boolean - 如果当前迭代位置是最后一位时返回true
    88. modulus(operand : int) : int - 返回当前计数(从1开始)与指定操作数的模数  
    89. 假定输出一个List 
    90. <s:iterator value="list" status="L"> 
    91.    <s:property value="#L.index"/> 
    92. </s:iterator> 
    93. 6)、最后再来看下在iterator中调用value stack的用法。  
    94. 假定countries是一个List对象,每一个country有一个name属性和一个citys List对象,并且每一个city也有一个name属性 。那么我们想要在迭代cities是访问countries的name属性就的用如下方式: 
    95. view plaincopy to clipboardprint? 
    96. <s:iterator value="countries">   
    97.     <s:iterator value="cities">   
    98.         <s:property value="name"/>, <s:property value="[1].name"/><br>   
    99.     </s:iterator>   
    100. </s:iterator>   
    101.            <s:iterator value="countries"> 
    102.                <s:iterator value="cities"> 
    103.                    <s:property value="name"/>, <s:property value="[1].name"/><br> 
    104.                </s:iterator> 
    105.            </s:iterator>  
    106. 这里的 <ww:property value="name"/>取的是ctiy.name;<ww:property value="[1].name"/>取得是country.name  
    107. <ww:property value="[1].name"/> 等价于 <ww:property value="[1].top.name"/>  
    108. we refer to a specific position on the stack: '[1]'. The top of the stack, position 0, contains the current city, pushed on by the inner iterator; position 1 contains the current country, pushed there by the outer iterator.(city处于当前栈,即top或者[0],而[1]指明了外层iterator对象,即country)  
    109. '[n]'标记引用开始位置为n的子栈(sub-stack),而不仅仅是位置n处的对象。因此'[0]'代表整个栈,而'[1]'是除top对象外所有的栈元素。 
  • 相关阅读:
    java实现第七届蓝桥杯方格填数
    java实现第七届蓝桥杯方格填数
    Java实现第八届蓝桥杯正则问题
    Java实现第八届蓝桥杯正则问题
    手把手教你用Mysql-Cluster-7.5搭建数据库集群
    MySQL集群---②Windows平台搭建MySQL CLUSTER集群
    mysql集群搭建教程-基础篇
    Mysql多实例的配置和管理
    MySQL 使用mysqld_multi部署单机多实例详细过程
    [MySQL 5.1 体验]MySQL 实例管理器 mysqlmanager 初试
  • 原文地址:https://www.cnblogs.com/limingluzhu/p/2685901.html
Copyright © 2011-2022 走看看