Display Tag Lib是一个标签库,用来处理jsp网页上的Table,功能非常强,可以对的Table进行分页、数据导出、分组、对列排序等等,反正我在做项目时需要的功能它都给我提供了,而且使用起来非常的方便。能够大大减少代码量。     介个是Display Tag的官方网站http://displaytag.sourceforge.net。 首先当然是要下载它的jar包了,这里可以下载到最新的版本。将jar包放到WEB-INF的lib文件夹下。另外还需要两个辅助包:apache的commons-lang和standard包,更多的辅助包可以在这里下载。

在web.xml下添加一个filter

<filter>

<filter-name>exportFilter</filter-name>

<filter-class>org.displaytag.filter.ResponseOverrideFilter</filter-class>

</filter>

在jsp页面做一个引用: <%@ taglib uri="http://displaytag.sf.net/el" prefix="display" %>

首先我们定义一个list  <% List test = new ArrayList( 6 );  test.add( "Test String 1" ); test.add( "Test String 2" );  test.add( "Test String 3" );  test.add( "Test String 4" ); test.add( "Test String 5" );  test.add( "Test String 6" ); request.setAttribute( "test", test ); %> 
    当我们想在jsp页面上显示这个list时,我们只需要写一句话     <display:table />     display tag会自动生成一个table

如果list是从控制层抛出来的,name可使用EL表达式表示     <display:table />

这是最简单的display tag的使用,我们可以给它加上样式等,也可以定义显示的列,下面的table显示复杂一些

<display:table styleClass="list" cellspacing="0" cellpadding="0">

<display:column property="id" title="ID" />

<display:column property="name" />

<display:column property="email" />

<display:column property="description" title="Comments"/>

</display:table>

如果想要给它加个链接也很简单,下面的代码给name加了连接,并附带id参数,email也自动连接到mailto:XXX

<display:table styleClass="list" cellspacing="0" cellpadding="0">

<display:column property="id" title="ID" />

<display:column property="name" url="detail.jsp" paramId="id" paramProperty="id"/>

<display:column property="email" autolink="true"/>

<display:column property="description" title="Comments"/>

</display:table>

下面介绍几个Display最常用的功能,更多功能请参考http://www.displaytag.org/index.jsp。 1. 分页     如果想对代码分页,只需在display:table标签中添加一项pagesize="每页显示行数",如 <display:table pagesize="10"/>

2. 对列排序     display tag可对列进行排序,就是点击列名,对该列的数据进行排序。你只需对想要排序的列添加 sort="true" 就OK,如下面的代码可对前三列进行排序。在display:table中添加defaultsort="列数",可默认对指定的列排序。

<display:table styleClass="list" cellspacing="0" cellpadding="0" defaultsort="1">

<display:column property="id" title="ID" sort="true"/>

<display:column property="name" url="detail.jsp" paramId="id" paramProperty="id" sort="true"/> <display:column property="email" autolink="true" sort="true"/>

<display:column property="description" title="Comments"/>

</display:table>

如果table有分页,Display Tag默认只对当前页进行排序,如果想对整个list排序,可以在display:table之间添加一段代码: <display:setProperty value="list"/>

3. 导出数据     在display:table中添加export="true",看看会出现什么!Display Tag默认会提供三种数据导出方式:CSV、Excel、XML 。     另外Display Tag还可以导出为PDF格式,在http://prdownloads.sourceforge.net/itext/下载一个辅助包iText.jar,copy到lib目录下,然后在display:table之间添加一段代码: <display:setProperty value="true"/>,大功告成。

4. Display Tag的属性设置     前面所说的display:setProperty 是一种改变Display Tag属性的方法,但是在每个jsp中都要写太麻烦了。     Display Tag中设置了很多默认的属性,它有一个专门的属性文件,是在它的jar包中的displaytag/properties/TableTag.properties     想要改变它的默认属性,我们可以在WEB-INF/classes下新建一个文件displaytag.properties,仿照TableTag.properties中属性的格式设置需要修改的属性。     TableTag.properties中的# messages中设置的是显示在页面上的提示信息。默认是英文的,我们可以把它改为中文的。不过这里只能使用unicode,就是说中文字符必须转换为unicode码,这个可以使用jdk自带的native2ascii.exe进行转换。

6. displaytag的翻页机制 这可能是displaytag的局限性了,它的翻页机制是这样的: 如果一个list中有10000个bean,按照它的机制,如果是第一页(每页n条),它会把前n条数据取出来,然后再把剩余的10000-n条删除,当你点击页面“2”的时候,它再从后台绕一圈,把第二页的数据,也就是把第n+1-2n条记录取出来,把剩余的删除。这样,它实现了翻页,又防止了内存占用过大。 但是,不管怎么说,它还是有一个取出所有条数的动作的,在极大数据量的情况下,有可能造成内存溢出。

8. displaytag中decorator一例

import org.displaytag.decorator.TableDecorator;

import Java.util.HashMap;

import java.text.SimpleDateFormat; import java.util.Date;

public class BulletinListDecorator extends TableDecorator{

private String bulletinId = null;

private String title = null;

private SimpleDateFormat sdf = null;

private int i = 0;

public BulletinListDecorator() {

sdf = new SimpleDateFormat("yy-MM-dd"); }

public String getBulletinId(){

i+=1;

return ""+i;

}

public String getTitle(){

bulletinId = (String)((HashMap) this.getCurrentRowObject()).get("bulletinId");

title = (String)((HashMap) this.getCurrentRowObject()).get("title");

return ""+title+""; }

public String getLastPubD(){

return sdf.format((Date)((HashMap) this.getCurrentRowObject()).get("lastPubD"));

}

}

<display:table  decorator="com.ztesoft.ds.application.web.bulletin.decorator.BulletinListDecorator">         <display:column property="bulletinId" titleKey="titlePage.seq" align="center" headerClass="ValueTd"/>         <display:column property="title" titleKey="titlePage.title" align="center" headerClass="ValueTd"/>         <display:column property="lastPubD" titleKey="titlePage.time" align="center"  headerClass="ValueTd"/>         <display:column property="className" titleKey="titlePage.class" align="center" headerClass="ValueTd"/>   <display:column property="clickNo" titleKey="titlePage.clickNo" align="center" headerClass="ValueTd"/>     </display:table>

其中bulletinList是一个ArrayList,titleKey指向了properties文件

补充:

一:

在display:table中添加自定义的列用 display:column ,将其属性media的值设置为html即可,如下例子:

<display:table name="list" pagesize="5" >

<display:column title="删除" media="html">

<input type="button" value="删除" />

</display:column>

</display:table>

二:

在写对应于bean里面的列时,display:column 中property对应的值是bean里面的属性的名字,大小写必须一致,例如:有个actionform类,有属性 private String _Name; 则property的值也必须为"_Name",否则提示找不到列。

*****************************************************************

转:

displaytag 学习笔记总结(1)

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

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

(   自认为这个功能一般。   因为连接的内容和显示的内容通常不一样。   )  当然可以在<display:column href="">在这里给某列指定所有的链接为同一个连接。  或者<display:column ><a href="">sdfs</a></display:column >两者效果是一样的。

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

8,使用装饰类来转换数据。

<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。

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

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

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

第二种方法比较好些,因为可以显得更灵活。想怎么写就怎么写。第一种方法就是简单地实现。   10,翻页。  1,怎么得到每行的序号?   <display:table id="xxx" ...>   使用<%=pageContext.getAttribute("xxx_rowNum")%>肯定好用。    但是<c:out value="${row_rowNum}"/>这种方式就不好用。也不知道差哪了。

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

11,自动设置排序   <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了。

12,如何分组   按照某列进行分组显示。   这个功能真不错。   <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 错误。

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

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

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

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

15,配置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使用资源文件的方法)

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

17,表格里面还有表格.   很简单.只要在外层表的   <dispaly:column>    ( 在这加<display:table ...>。。。    </display:table>即可)   </display:column>         18,表头表尾   很简单:<dispaly:caption><display:footer>想<display:column>一样使用就行了.   主要注意一下: <display:footer>内容必须是<tr>.....</tr>

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

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

============================================= 关键: 20,如何分页.    因为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还有一些很实用的小功能,这里提两个。一个是对数据的Format,这是1.1版本添加的新功能,可以使用标签的方式格式化时间、数字、字符串。比如日期,在需要格式化的column标签中添加format="",第一个参数为格式化的数据序号,第二个参数是数据类型,数字为 number,第三个参数为数据格式。
    另外一个功能是对table数据的合计功能。在table标签中添加 decorator="org.displaytag.decorator.TotalTableDecorator",然后在想要进行合计的数据列的 column标签中添加 total="true",该列就可以被计算总数了。但这个功能有个缺点,不能用在有分页的时候,它只能合计第一页的数据。

DisplayTag的不足
    初次使用DisplayTag的人可能会觉得惊喜,但是用久了会发现很多问题,最大的问题是对中文的支持不好,比如如果查询条件中有中文,就无法翻页,无法对中文排序,将中文导出为指定文件时出现乱码等等。这些问题有时候会让人很郁闷,有时候逼得你要去修改它的源代码。下面是对以上几个问题的解决方法:
    1. 对于中文无法翻页、排序,最简单的办法是修改Tomcat下的server.xml文件。找到HTTP的Connector标签,在里面添加一项 URIEncoding="...",引号里面的内容取决于你的页面编码,比如可以是GBK,UTF8等。这样上面两个问题就可以解决了。
    2. 导出为文件:其实这个功能除了中文支持外还有很多其它问题,比如它会将Html标签一起导出、只导出显示的内容,但如果对table进行了 decorator,decorator后的内容无法导出。如果想要将中文正确导出,需要修改DisplayTag源代码。
    下载相同版本的源代码,在org.displaytag.export.ExcelView.java文件中找到getMimeType()方法,将此方法修改为 return "application/vnd.ms-excel;charset=GB2312";,修改后导出数据的速度会慢很多,不过将就吧。
    3. 新版的DisplayTag1.1添加了对一次取部分数据的支持,相关的标签包括partialList和size,需要设置partialList="true"和size的大小。具体怎么用偶还没研究。

Display Tag Lib Table进行分页的更多相关文章

  1. html中使用js+table 实现分页

    本文在html中利用js+table实现分页.主要思想是先对table中的所有数据隐藏,然后通过当前页面(currPageNum)来计算当前页要显示的行,并显示出来,首页.下一页.上一页.尾页都依此来 ...

  2. 利用JS实现HTML TABLE的分页

    有时候table的列数太长,不利于使用者查询,所以利用JS做了一个table的分页,以下为相关代码 一.JS代码 <script type="text/javascript" ...

  3. MySQL+Service+Servlet+Jsp实现Table表格分页展示数据

    下面以一个示例讲解如何使用MySQL+Service+Servlet+Jsp实现Table表格分页展示数据: eg:请假管理系统 要求如下: 一.打开首页页面, 访问查询请假记录的 servlet , ...

  4. bootstrap table 服务器端分页例子分享

    这篇文章主要介绍了bootstrap table 服务器端分页例子分享,需要的朋友可以参考下 1,前台引入所需的js 可以从官网上下载 复制代码代码如下: function getTab(){var ...

  5. (网页)table加上分页,优点可随便加样式

    1.先有静态的页面: <div class="col-xs-12"> <table id="tbtablesaleinfo" class=&q ...

  6. layui之layer打开table后分页无效的解决方法

    1.原代码: <body> <div id="showalladdableavms" style="display: none;width:100%&q ...

  7. 161222、Bootstrap table 服务器端分页示例

    bootstrap版本 为 3.X bootstrap-table.min.css bootstrap-table-zh-CN.min.js bootstrap-table.min.js 前端boot ...

  8. [前端插件]Bootstrap Table服务器分页与在线编辑应用总结

    先看Bootstrap Table应用效果: 表格用来显示数据库中的数据,数据通过AJAX从服务器加载,同时分页功能有服务器实现,避免客户端分页,在加载大量数据时造成的用户体验不好.还可以设置查询数据 ...

  9. C# Bootstrap table之 分页

    效果如图: 一.声明talbe <div class="container"> <table id="table" class="t ...

随机推荐

  1. OS选择题练习

    一.死锁 1.设系统中有n个进程并发,共同竞争资源X,且每个进程都需要m个X资源,为使该系统不会发生死锁,资源X的数量至少为() A.n*m+1 B.n*m+n C.n*m+1-n   D.无法预计 ...

  2. oracle数据库与其他数据库区别

    本文用的是Oracle 10g数据库,利用PL/SQL Developer的集成开发环境(安装可以自行百度) Oracle数据库  ---> 数据库实例  --->  表空间(逻辑单位)( ...

  3. IP地址 子网掩码 网络地址 主机地址 广播地址

    1.一定要明白各自的概念分别表示什么 IP地址:IP地址是用来识别网络上的设备,因此,IP地址是由网络地址与主机地址两部分所组成. 子网掩码:子网掩码不能单独存在,它必须结合IP地址一起使用.子网掩码 ...

  4. 某 游戏公司 php 面试题

    1.实现未知宽高元素的水平垂直居中,至少两种方法. <div, class="father"> <div class="son">< ...

  5. 模块 json 和 pickle

    目录 序列化 json 和 pickle 模块 序列化 序列:字符串 序列化:将其它数据类型转换成字符串的过程. 反序列化:字符串转成其它数据类型. 序列化的目的 1:以某种存储形式使用自定义对象持久 ...

  6. 选择排序——C语言

    选择排序 1.算法描述 首先在未排序序列中找到最小(大)元素,存放到排序序列的起始位置,然后,再从剩余未排序元素中继续寻找最小(大)元素,然后放到已排序序列的末尾.以此类推,直到所有元素均排序完毕(放 ...

  7. docker 实践二:操作镜像

    本篇我们来详细介绍 docker 镜像的操作. 注:环境为 CentOS7,docker 19.03 之前已经说过,容器是 docker 的核心概念之一,所以对应的就需要知道它的使用方法,接下来我们就 ...

  8. SVN操作出现locked错误解决办法

    SVN操作出现locked错误解决办法:在SVN中执行 commit 操作时,在更新过程中,中断过,或者因为其他原因导致SVN 出现 locked 异常. 解决办法:1. 选中出现异常的文件,右键 - ...

  9. BZOJ3998 TJOI2015弦论(后缀自动机)

    先考虑相同子串视为一个.按SAM的拓扑序预处理出从每个节点开始能得到多少个本质不同子串(注意虽然一个节点对应多个子串,但到达该点时当前的子串显然是确定为其中一个的),然后按位贪心即可. 相同子串视为多 ...

  10. jenkins 安装插件失败

    大家在使用jenkins安装插件的时候经常遇到一下问题,就是插件由于网络或者墙的原因无法直接下载,出现下面截图的问题,处理办法有两种 第一种:更换源的问题jenkins->系统管理->管理 ...