`

struts2迭代数组+反向迭代

阅读更多
今天遇到一个特殊需求,要求统计图采用时间升序显示,表格采用时间降序排列,由于统计图与表格都是使用的同一个数据源,那么迭代显示表格时必须采用反向迭代,那么怎样迭代呢?下面我们一起看看,其实比较简单。

1.(数据源)举例:[cvs:{1567.0,0.0,1422.0,1468.0,1440.0},labels:{2014-04-18 15:56',2014-04-18 16:00','2014-04-22 14:56','2014-04-22 15:03','2014-04-22 17:31'}]

2.看以上数据时间是升序的,如果采用以下迭代的话,那么表格显示的也是升序,没有达到产品要求:
<s:set name="dates" value="healthData['labels']" />
<s:set name="values" value="healthData['cvs']" />
<s:iterator value="dates" var="date" status="index">
  <tr>
    <td><s:property value="#index.index+1"/></td>
    <td><s:property value="date"/></td>
    <td><s:property value="#values[#index.index]"/> mmHg</td>
    <td>-</td>
    <td>-</td>
  </tr>
</s:iterator>

3.经过分析,只要知道了values,dates数组的长度,那么我们可以减去index.index这个索引,那么这样就能达到要求,且看如下代码:
<s:set name="dates" value="healthData['labels']" />
<s:set name="values" value="healthData['cvs']" />

<s:iterator value="dates" var="date" status="index">
  <tr>
    <td><s:property value="#index.index+1"/></td>
    <td>
       <s:property value="#dates[#dates.size()-#index.index-1]"/>
    </td>
    <td>
       <s:property value="#values[#values.size()-#index.index-1]"/> %   
    </td>
    <td>-</td>
    <td>-</td>
  </tr>
</s:iterator>
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics