Displaytag的使用二(转)

1.列表的子集
<display:table name="mylist" offset="m" length="n"/>
offset 为第一个数据在mylist中的序号。
length 为显示的记录条数。

2.自动设置链接  
能够把此列的内容作为链接,连接的url和内容一致。
    当然必须格式有效的url,否则写了也没有连接。


   自认为这个功能一般。
   因为连接的内容和显示的内容通常不一样。

当然可以在<display:column href="">在这里给某列指定所有的链接为同一个连接。
或者<display:column ><a href="">sdfs</a></display:column >两者效果是一样的。

!!!那么,如果连接的url不是列内容,而且每行的链接都不相同,这个时候怎么办?
   就好像广告列表有商户名称,商户名称是一个连接,连接到商户的具体信息页面。
   连接的url肯定不同。如何处理?

现在还不知道,接着往下看。

3.使用装饰类来转换数据。

<display:table name="test" decorator="org.displaytag .sample.Wrapper" >
用来转换数据内容的。一般用来格式化信息。
此类必继承TableDecorator。
顺便介绍一个格式化时间的包 org.apache.commons.lang.time.FastDateFormat;
格式化金钱的包 java.text.DecimalFormat;

思路就是覆盖List中具体类型的getXXX方法。
this.getCurrentRowObject() 得到当前行的数据。
this.getListIndex() 得到当前行的序号。
之后就转化为List中存放的具体类型,之后得到某列的数据。
返回格式化后的数据。

!!!!另外我看到,装饰类增加了一些getXXX方法,这些方法并没有在ListObject中定义。
还不知道这样做有什么好处?

<display:column property="date" decorator="org.displaytag .sample.LongDateWrapper" />
这样仅仅对一列数据进行格式化,需要继承ColumnDecorator
需要实现:String decorate(Object columnValue)方法。此方法同样接受一个Object参数,
   此参数就是对象的某个具体属性值,直接转化为对应类型,然后格式化,返回String。


4.建立动态链接。
两种方式可以建立动态链接。
    第一种方式直接在页面上使用
   <display:column href="baseurl" paramId="paramid" />
  
http://baseurl/paramid=columnvalue
   <display:column href="baseurl" _fcksavedurl=""baseurl"" _fcksavedurl=""baseurl"" _fcksavedurl=""baseurl"" _fcksavedurl=""baseurl"" paramId="paramid" paramName=“name” paramScope="scope"/>
  
http://baseurl/paramid=scope 范围内的名字为name的值
   <display:column href="baseurl" _fcksavedurl=""baseurl"" _fcksavedurl=""baseurl"" _fcksavedurl=""baseurl"" _fcksavedurl=""baseurl"" paramId="paramid" paramProperty=“propertyname”/>
  
http://baseurl/paramid =名字为propertyname的属性值

这种方式处理简单的链接十分有效,但是链接参数值如果通过查询数据库等比较复杂的方式得到的话,这种方式
就不适应了。这时候就必须使用第二种方法。

第二种方法,在装饰类中获得连接。
   装饰类多定义一些getXXX方法,那么页面上就可以使用<display:column propety="XXX" ..>来使用装饰类de
   getXXX方法。好,这样一来,在装饰类的getXXX方法里,得到此行对象,这样对象的各个属性就都能得到,
   之后去查数据库也好,去完成负责的判断逻辑也好,都很容易实现,别忘了,然后拼装起来,并写成一个
   <a href="....">这样的字符串返回。
   好,页面直接一句话就可得到此拼装的《a》了。<display:column propety="XXX" ..>

第二种方法比较好些,因为可以显得更灵活。想怎么写就怎么写。第一种方法就是简单地实现。

5.翻页。
1,怎么得到每行的序号?
   <display:table id="xxx" ...>
   使用<%=pageContext.getAttribute("xxx_rowNum")%>肯定好用。
   但是<c:out value="${row_rowNum}"/>这种方式就不好用。也不知道差哪了。

   翻页很简单。就是在<display:table pagesize="m">这样来指定每页的数量就可以了。
   自动出现换页的索引,上下页等等东西。
   实在是方便。但是问题就是一次传下来很多东西,性能不好。等一会看看如何改良。


6.自动设置排序
   <display:table name="sessionScope.stest" defaultsort="1" defaultorder="descending">
   <display:column property="id" title="ID" sortable="true" headerClass="sortable" />
   可以设定默认时按照哪列排序,是升序还是降序。本例设置第一列默认时降序。
   每列都得对象都必须实现了Comparable接口才能被设置成sortable="true".
   如果没有实现Comparable,那么必须写一个装饰类。
   另外需要注意,
    他只对当前页面进行排序。而不是全部。在翻页时特别需要注意。
    要想实现全部的排序,那么必须重新写Action往网页传新的List了。

7.如何分组
   按照某列进行分组显示。
   这个功能真不错。
   <display:column property="city" title="CITY" group="1"/>
   <display:column property="project" title="PROJECT" group="2"/>
   这样不仅仅结果可以分组,而且还可以省略掉重复的数据,例如city列,project列都有
   A ,B ,A,B 两行那么第二行这两列就不显示了。

   同样只能对当前页进行分组。

   注意:第一列一定要1,第二列一定是2,否则出NUllPoint 错误。

8.统计
   好东西啊。可以对分组进行统计,也可以对所有行进行统计。
   主要靠TableDecorator类finishRow()返回统计结果,放到页面去显示。

   TableDecorator类方法getDecoratedObject()得到整个结果集。一般把它转化成List,因为大多数情况下结果
   是存放在List中的。
   public final String finishRow() {}当一行结束时执行此方法。所以用它来判断是否需要计算城市统计,
    抑或是全部统计。
   相当于事件处理。返回的字符串也将在页面上显示。本例返回了<tr><td>...</td><tr> 这样的三份。
   这样就在表中嵌套进了三行。用来显示统计是足够了。

9.导出数据
   很简单。talbe里设置export=“true”就行了。配置文件也要设置好export.xml = true , 这样才能导出xml。
   类推pdf、excel、html、csv。
   每个列能配置是否在某种格式中显示,语法<display:column media="csv excel" 。。
   不配置就在所有格式中都显示。

   另外需要注意:
    被包含的文件不能使用这个功能,非要使用,就的用过滤器。以后再深研究吧。

10.配置DisplayTag .
   在应用的classpath路径上拷贝一个TableTag.properties,并命名为displaytag .properties.
   这样就默认取displaytag .properties里的配置了。想汉化,很简单。就需要把displaytag _zh.properties 放到
   classpath路径下就可以了。

   标题像汉化:因为默认是jstl的资源文件使用方式。所以得先学习jstl的
   我知道了jstl.fmt如何使用资源文件。好了,jstl 首先必须用fmt:bunlle指定一个资源文件,然后才能
   在他的body部分使用此资源文件,颇麻烦。

   而displaytag 呢? 没有这么麻烦,如果与struts搭配使用,适用struts的资源文件当然最合理了。
   你必须在displaytag .properties里定义好一个
   参数,#locale.provider=org.displaytag .localization.I18nJstlAdapter
    locale.provider=org.displaytag .localization.I18nStrutsAdapter
   就这么简单,就能够使用struts配置文件了。我今天竟然看了一下午。哎,苦于没有好点的资料啊。

   问题是:如果不合struts搭配使用。如果仅仅在jstl环境下,displaytag 又该如何 使用jstl的资源文件呢?
   你必须象在jstl环境里一样使用<fmt:bundl>指定好资源文件,之后把displaytag 标签放 到他的body
   后,就可以使用jstl的资源文件了!!!!(幸亏我首先看了jstl使用资源文件的方法)


11.一个页面两个以上的表格.
   很简单,只需要每个表格配置不同的id.

12.表格里面还有表格.
   很简单.只要在外层表的
   <dispaly:column>
    ( 在这加<display:table ...>。。。
    </display:table>即可)
   </display:column>

  
  
13.表头表尾
   很简单:<dispaly:caption><display:footer>想<display:column> 一样使用就行了.
   主要注意一下: <display:footer>内容必须是<tr>.....</tr>

14.表格里的值截断,与显示空白.
<display:column property="nullValue" nulls="false"/>
<display:column property="longDescription" maxLength="10" style="whitespace: nowrap;"/>
简单得很.

ok,差不多到了关键的时候了。!!!!!

=============================================
关键:
15.如何分页.

因为displaytag 的分页机制需要一次把所有纪录都传到里面.所以对纪录很多的项目并不合适.如果还非得用
displaytag 那 只好放弃他的一些功能了.比较理智的方法是仅仅让displaytag 获得一页 的list.这样就不用
displaytag
的分页index,而使用自己的,或者写customertag,或者使用jsppager tag.

有很多人质疑这种方法,因为这使得displaytag 的 光芒至少减少了一半以上,因为他的很多功能因此而无法使用,
例如排序功能,可以针对所有list进行全局排序,如果每次只传给一页的数据,全局排序就和当页排序没有区别了.
displaytag 的 全局排序功能宣布废掉了.

<display:table name="mylist" offset="m" length="n"/>这样的功能基本上也没有什么用处。


那么还使用它干什么呢? displaytag 即使废掉 了一些武功仍然有它的优点.例如
1,支持表格的嵌套.
2,支持css这样就能写少量地代码使得程序更简洁.只好定义好一套css,就能全局范围内使用了.
3,另外还支持截断长的字符串,这样就不用在页面使用自己的方法了.
4,能够实现比较复杂的逻辑从而产生动态链接。这也勉强所以个好处吧。
5,能轻松地使用struts的资源文件。使得它可以很好的国际化。
6,能够过滤空值。


缺点:
1,分组就使用不了了,统计也无法使用了。只统计当前页是没有意义的。
2,排序也变成当前页排序了。没多少意思。
3,导出也变成当前页导出了,没多少意思了。

你可能感兴趣的:(Displaytag的使用二(转))