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,导出也变成当前页导出了,没多少意思了。
分享到:
相关推荐
JSP Display标签的配置和使用 JSP Display标签是一种功能强大且灵活的标签,用于在Web应用程序中显示数据。DisplayTag提供了多种方式来显示数据,包括表格、树形结构、 csv、excel、pdf等。下面将详细介绍...
本篇文章将深入探讨如何在JSP中使用标签库,以及与之相关的技术和工具。 首先,我们要了解JSP标签库的基本概念。JSP标签库是由一组相关标签组成的集合,这些标签可以实现特定的功能,如数据处理、用户界面展示等。...
使用Display Tag进行分页,可以在JSP页面上通过简单的标签实现,减轻了前端开发的工作量。 Display Tag的分页功能主要通过`<display:table>`标签实现,可以设置页码、每页记录数等参数,通过`<display:column>`标签...
在MyEclipse中,导入Display Tag库的JAR文件,然后创建一个JSP页面,结合后台数据源(如JavaBean或DAO),就可以使用上述标签创建功能丰富的表格。 ```jsp <%@ taglib prefix="display" uri=...
在SSHConformity中,`display标签`和`taglib标签`是两个重要的组件,主要用于页面展示和数据分页。 1. **Display Tag Library**: Display Tag是一个功能强大的JSP标签库,它提供了多种用于表格展示和操作的标签。...
### jsp-config标签使用详解 在JavaServer Pages (JSP)技术中,`jsp-config`元素主要用于指定一组适用于整个Web应用程序或特定页面的配置参数。这些配置参数可以在部署描述符(web.xml)文件中定义,也可以通过注解...
`userlist.jsp` 是使用自定义标签展示数据列表的页面,它通过`<taglib>`指令引用自定义标签库,并在页面中使用自定义标签`<user:displayList>`来展示用户列表。在`<user:displayList>`标签中,可以传递参数,如数据...
然后,在JSP页面中,使用Display Tag标签创建分页: ```jsp <table class="display" displaytag:table="users" displaytag:sort="list" pagesize="${pageSize}"> 用户名 邮箱 <!-- 添加其他列头 --> ...
本话题主要探讨如何使用JavaScript(js)结合JavaServer Pages(jsp)标签来实现这样的功能。JavaScript是客户端脚本语言,负责处理用户交互,而jsp标签则是在服务器端执行,生成动态HTML内容。 首先,我们需要理解...
6. **JSP渲染**:JSP接收到模型数据后,使用分页标签渲染出分页链接和当前数据。 在压缩包中的"集成后的分页标签"可能包含了一个已经配置好的分页标签库示例,你可以参考这个例子学习如何在实际项目中集成和使用...
- `<display-name>`:标签库的显示名称。 - `<icon>`:库的图标信息。 - `<uri>`:用于标识标签库的URI。 - `<tag>`:定义自定义标签。 - `<tag-class>`:自定义标签处理器类的全限定名。 - `<body-content>`...
在IT行业中,尤其是在Web开发领域,`jsp_table_display`是一个常见的任务,涉及到使用JavaServer Pages (JSP) 技术来动态地展示数据库中的数据。在这个案例中,我们看到一个名为"shiyan.zip"的压缩包,其中包含了...
为了更好地利用Display Tag,开发者需要对JSP标签库有一定的了解,并熟悉如何配置和使用相关标签。此外,理解数据绑定和MVC模式也是必要的,因为Display Tag通常与Spring MVC或其他类似框架集成使用。 总的来说,...
1. **JSP语法**:如何在JSP页面中嵌入Java代码,使用JSP动作标签,以及使用EL(Expression Language)和JSTL(JavaServer Pages Standard Tag Library)表达逻辑。 2. **DisplayTag的使用**:如何配置DisplayTag库,...
DisplayTag 是一个强大的开源 JSP 标签库,专门用于创建复杂的表格展示,包括排序、分页、格式化数据等功能。在网页开发中,DisplayTag 可以极大地简化表格的生成,提高开发效率。 首先,我们需要在 `web.xml` 文件...
在JSP页面上,使用`<display:table>`标签来创建一个表格。该标签有许多属性,例如`name`用于指定数据源,`export`控制是否导出数据,`sort`和`order`用于控制排序等。表格中的列可以使用`<display:column>`标签定义...
为了自定义列的显示,你可以使用`<display:column>`标签。例如,以下代码将显示对象的`id`、`name`、`email`和`status`属性: ```jsp <display:table name="test"> <display:column property="id" title="ID" /> ...
【标签】"源码"和"工具"暗示了我们可能在讨论如何查看和修改JSP源代码,以及使用特定的开发工具。源码是程序的基础,理解JSP源码有助于调试和优化表格布局问题。而“工具”可能指的是IDE(集成开发环境)如Eclipse、...