zoukankan      html  css  js  c++  java
  • 利用Struts2标签实现多列显示数据

    假如有jsp页面要实现一个列表信息,格式如下:
    第1条信息 第2条信息
    第3条信息 第4条信息
    第5条信息 第6条信息
    第7条信息 第8条信息
    .....

    搜索过别的方法,很多人运用jsp代码写入页面来进行循环判断。其实用struts2自带的标签可以实现同样效果,利用iterator标签进行循环,里面用if标签判断何时加入tr标签的开头和结尾,下面实现了两列信息列表的情况:


    Java代码 复制代码
    1. <table width="540" border="0" cellspacing="0" cellpadding="0">   
    2.        <s:iterator value="cooperList" status="st">   
    3.   
    4.          <s:if test="#st.odd||#st.first">   
    5.               <tr>       
    6.          </s:if>   
    7.   
    8.        <td width="200" height="20">   
    9.          <a href="showSelCooper.action?oid=<s:property value="oid" />" target="_blank"><s:property value="title"/></a></td>   
    10.   
    11.         <s:if test="#st.even||#st.last">   
    12.               <tr>       
    13.         </s:if>   
    14.         </s:iterator>   
    15.                 </table>  



    因为iterator标签有如下方法:
    boolean isEven() 当前迭代元素索引是否为偶数;
    boolean isOdd() 当前迭代元素索引是否为奇数;
    boolean isLast() 是否为最后一条元素;
    boolean isFirst() 是否为第一条元素。
    有以上元素,那么判断何时加入tr就非常方便。

    假如是多列(两列以上),那么我们就可以使用如下方法:
    int getIndex() 返回当前迭代元素的索引
    用它来计算你何时需要加入tr标签的开头和结尾,无非就是if判断的表达式复杂一些,方法还是一样的。
    假如是多列(两列以上),那么我们就可以使用如下方法:
    int getIndex() 返回当前迭代元素的索引
    用它来计算你何时需要加入tr标签的开头和结尾,无非就是if判断的表达式复杂一些,方法还是一样的。

    <s:if test="#st.getIndex()%3==0||#st.first">
    <tr>
    </s:if>
  • 相关阅读:
    网络协议栈(6)RFC793TCP连接时部分异常流程及实现
    网络协议栈(5)sendto/send返回成功意味着什么
    LeetCode——Detect Capital
    LeetCode——Find All Numbers Disappeared in an Array
    LeetCode——Single Number
    LeetCode——Max Consecutive Ones
    LeetCode——Nim Game
    LeetCode——Reverse String
    LeetCode——Next Greater Element I
    LeetCode——Fizz Buzz
  • 原文地址:https://www.cnblogs.com/jamin/p/1231121.html
Copyright © 2011-2022 走看看