JSPDisplay标签的使用

更新时间:2023-06-14 23:43:18 阅读: 评论:0

JSPDisplay标签的使⽤
Display Tag Lib是⼀个标签库,⽤来处理jsp⽹页上的Table,功能⾮常强,可以对的Table进⾏分页、数据导出、分组、对列排序等等,反正我在做项⽬时需要的功能它都给我提供了,⽽且使⽤起来⾮常的⽅便。能够⼤⼤减少代码量。 介个是Display Tag的官⽅⽹站
displaytag.sourceforge。 ⾸先当然是要下载它的jar包了,这⾥可以下载到最新的版本。将jar包放到WEB-INF的lib⽂件夹下。另外还需要两个辅助包:apache的commons-lang和standard包,更多的辅助包可以在这⾥下载。
在l下添加⼀个filter
<filter>
<filter-name>exportFilter</filter-name>
<filter-class>org.displaytag.filter.ResponOverrideFilter</filter-class>
</filter>
在jsp页⾯做⼀个引⽤: <%@ taglib uri="displaytag.sf/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.tAttribute( "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最常⽤的功能,更多功能请参考www.displaytag/index.jsp。 1. 分页 如果想对代码分页,只需在display:table标签中添加⼀项pagesize="每页显⽰⾏数",如 <display:table p
agesize="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:tProperty value="list"/>
3. 导出数据 在display:table中添加export="true",看看会出现什么!Display Tag默认会提供三种数据导出⽅式:CSV、Excel、XMLphone什么意思
。 另外Display Tag还可以导出为PDF格式,在prdownloads.sourceforge/itext/下载⼀个辅助包iText.jar,copy到lib⽬录下,然后在display:table之间添加⼀段代码: <display:tProperty value="true"/>,⼤功告成。
4. Display Tag的属性设置 前⾯所说的display:tProperty 是⼀种改变Display Tag属性的⽅法,但是在每个jsp中都要写太⿇烦了。Display Tag中设置了很多默认的属性,它有⼀个专门的属性⽂件,是在它的jar包中的displaytag/properties /TableTag.properties 想要改变它的默认属性,我们可以在WEB-INF\class下新建⼀个⽂件displaytag.properties,仿照 TableTag.properties中属性的格式设置需要修改的属性。 TableTag.properties中的# messages中设置的是显⽰在页⾯上的提⽰信息。默认是英⽂的,我们可以把它改为中⽂的。不过这⾥只能使⽤unicode,就是说中⽂字符必须转换为 unicode码,这个可以使⽤jdk⾃带的进⾏转换。
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;
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) CurrentRowObject()).get("bulletinId");
title = (String)((HashMap) CurrentRowObject()).get("title");
return ""+title+""; }
public String getLastPubD(){
return sdf.format((Date)((HashMap) CurrentRowObject()).get("lastPubD"));
}
}
<display:table decorator="soft.ds.application.web.bulletin.decorator.BulletinListDecorator"> <display:column
property="bulletinId" titleKey="titlePage.q" 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" offt="m" length="n"/> offt 为第⼀个数据在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。 顺便介绍⼀个格式化时间的包 s.lang.time.FastDateFormat; 格式化⾦钱的包
另外我看到,装饰类增加了⼀些getXXX⽅法,这些⽅法并没有在ListObject中定义。 还不知道这样做有什么好处?
<display:column property="date" decorator="org.displaytag.sample.LongDateWrapper" /> 这样仅仅
对⼀列数据进⾏格式化,需要继承ColumnDecorator 需要实现:String decorate(Object columnValue)⽅法。此⽅法同样接受⼀个Object参数, 此参数就是对象的某个具体属性值,直接转化为对应类型,然后格式化,返回String。
9,建⽴动态链接。 两种⽅式可以建⽴动态链接。 第⼀种⽅式直接在页⾯上使⽤ <display:column href="baurl" paramId="paramid" /> baurl/paramid=columnvalue <display:column href="baurl" paramId="paramid" paramName=“name”paramScope="scope"/> baurl/paramid=scope范围内的名字为name的值 <display:column href="baurl"
paramId="paramid" paramProperty=“propertyname”/> baurl/paramid=名字为propertyname的属性值
这种⽅式处理简单的链接⼗分有效,但是链接参数值如果通过查询数据库等⽐较复杂的⽅式得到的话,这种⽅式 就不适应了。这时候就必须使⽤第⼆种⽅法。
第⼆种⽅法,在装饰类中获得连接。 装饰类多定义⼀些getXXX⽅法,那么页⾯上就可以使⽤<display:column propety="XXX" ..>来使⽤装饰类de getXXX⽅法。好,这样⼀来,在装饰类的getXXX⽅法⾥,得到此⾏对象,这样对象的各个属性就都能得到, 之后去查数据库也好,去完成负责的判断逻辑也好,都很容易实现,别忘了,然后拼装起来,并写成⼀个 <a href="....">这样的字符串
装点门面
返回。 好,页⾯直接⼀句话就可得到此拼装的《a》了。<display:column propety="XXX" ..>
第⼆种⽅法⽐较好些,因为可以显得更灵活。想怎么写就怎么写。第⼀种⽅法就是简单地实现。 10,翻页。 1,怎么得到每⾏的序号?
<display:table id="xxx" ...> 使⽤<%=Attribute("xxx_rowNum")%>肯定好⽤。 但是<c:out
value="${row_rowNum}"/>这种⽅式就不好⽤。也不知道差哪了。
翻页很简单。就是在<display:table pagesize="m">这样来指定每页的数量就可以了。 ⾃动出现换页的索引,上下页等等东西。 实在是⽅便。但是问题就是⼀次传下来很多东西,性能不好。等⼀会看看如何改良。
11,⾃动设置排序 <display:table name="ssionScope.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”就⾏了。配置⽂件也要设置好l = 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="fal"/> <display:column
学习弹钢琴
property="longDescription" maxLength="10" /> 简单得很.
ok,差不多到了关键的时候了。
============================================= 关键: 20,如何分页. 因为displaytag的分页机制需要⼀次把所有纪录都传到⾥⾯.所以对纪录很多的项⽬并不合适.如果还⾮得⽤ displaytag那只好放弃他的⼀些功能了.⽐较理智的⽅法是仅仅让displaytag获得⼀页的list.这样就不⽤displaytag 的分页index,⽽使⽤⾃⼰的,或者写customertag,或者使⽤jsppager tag.
有很多⼈质疑这种⽅法,因为这使得displaytag的光芒⾄少减少了⼀半以上,因为他的很多功能因此⽽⽆法使⽤, 例如排序功能,可以针对所有list进⾏全局排序,如果每次只传给⼀页的数据,全局排序就和当页排序没有区别了. displaytag的全局排序功能宣布废掉了.
<display:table name="mylist" offt="m" length="n"/>这样的功能基本上也没有什么⽤处。
那么还使⽤它⼲什么呢? displaytag即使废掉了⼀些武功仍然有它的优点.例如 1,⽀持表格的嵌套. 2,⽀持css这样就能写少量地代码使得程序更简洁.只好定义好⼀套css,就能全局范围内使⽤了. 3,另外还⽀持截断长的字符串,这样就不⽤在页⾯使⽤⾃⼰的⽅法了. 4,能够实现⽐较复杂的逻辑从⽽产⽣动态链接。这也勉强所以个好处吧。 5,能轻松地使⽤struts的资源⽂件。使得它可以很好的国际化。 6,能够过滤空值。
缺点: 1,分组就使⽤不了了,统计也⽆法使⽤了。只统计当前页是没有意义的。 2,排序也变成当前页排序了。没多少意思。 3,导出也变成当前页导出了,没多少意思了。

本文发布于:2023-06-14 23:43:18,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/fan/82/956066.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:排序   数据   需要   属性
相关文章
留言与评论(共有 0 条评论)
   
验证码:
推荐文章
排行榜
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图