`
wl1985
  • 浏览: 41766 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

(原创)DisplayTag1.1最新使用心得小记

阅读更多
displayTag作为当前还算得上比较流行的表现层工具插件,在sourceForge官方网站(http://displaytag.sourceforge.net/)上,平均每天的访问量数以万计,本文是建立在实际开发过程中
碰到的导出excel报表的实际需求,所获得的一些学习心得与技巧与大家分享.
原文:[url]http://www.pben.cn/main.htm?action=read&bid=23&postID=8a8a8a8f163e65640116412a658a0e06 [/url]
默认的displayTag导出的Excel格式会有中文乱码,网上大部分文章都说只有改一下,org.displaytag.export.ExcelView类中,
public String getMimeType()
{
return "application/vnd.ms-excel"; //$NON-NLS-1$
}
方法,在方法后面追加;chartset=gbk;其它不尽然,如果这样改的话在tomcat作为web服务端的话,如果列表中有中文,很慢很慢才会有导出(不过,我至今尚未在tomcat下导出过中文),
把WEB应用布署在JBOSS下面,导出的话,如果数据量大的话也会有20-40秒不等,后来到displayTag的官网上,去看它的bugtrack,发现其实不尽然。其它displayTag如果在你需要导出excel并且想自已利用apache的
POI的话,要再去到官方网上下载一个displaytag-export-poi-1.1.jar的包,详细操作请看http://displaytag.sourceforge.net/11/install.html

其中里面谈到,如果,每次导出的excel数据总是有缓存的话,可以在web.xml文件中加入如下配置进行过滤,这样就可以导出实时数据了。
Configure the Filter in your web.xml:

<filter>
<filter-name>ResponseOverrideFilter</filter-name>
<filter-class>org.displaytag.filter.ResponseOverrideFilter</filter-class>
</filter>And add mappings for the pages that you will intercept, for example:

<filter-mapping>
<filter-name>ResponseOverrideFilter</filter-name>
<url-pattern>*.do</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>ResponseOverrideFilter</filter-name>
<url-pattern>*.jsp</url-pattern>
</filter-mapping>

从以上内容来看,也只是告诉你,如果要用apache的最新的POI的话,需要把displaytag-export-poi-1.1.jar从官网下载下来,放入你的工程文件中,
并没有说如何调用写自己的所需的excel的报表格式.下面就实际问题,来讨论一下如何让displayTag导出自己所需的excel格式.
在displayTag所提供的接口类中,导出自已所需的Excel有两种方式,一种是通过指定的excel模板,一种是对excel的所有的格子,一个个样式的处理,
后一种方式完全体现了“慢工出细活”的格言,而前一种方式实现起来显然要好用得多,只用读模板的样式就行了。如何调用displayTag对导出自定制的Excel文件
所提供的接口呢,请看下文,(不要急噢!^_^)
要调用displayTag给Poi所提供的接口操作步骤如下:
1,先要在你的appfuse工程中新建一个类,让其实现org.displaytag.export.BinaryExportView接口,其中关键的方法是
public void doExport(OutputStream out) throws JspException {
String captionvalue = this.model.getCaption();
// ExcelHssfView1 tempExcelView=new ExcelHssfView1();
// try {
// BeanUtils.setProperty(tempExcelView, "action",captionvalue);
// } catch (IllegalAccessException e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// } catch (InvocationTargetException e) {
// // TODO Auto-generated catch block
// e.printStackTrace();
// }
if (captionvalue != null) {
captionvalue = captionvalue.replaceAll("(\\r)|(\\n)|(\\t)", "");

doExportCommon(out);


} else {
System.out.println("exec Common");
doExportCommon(out);
}
}
对这个方法按照你的POI的定制excel报表的的方法,然后实现它,再把内容写入outputStream中去,基本上就可以了,当然如果有上面的

this.model.getCaption()是读取displayTag的页面标签<displayTag:caption/>标签中的内容,可以在不同的JSP页面放入不同的caption的值
从而判断调用不同的方法,生成不同的excel样式的报表,灵活性兼而有之.
写完以上类以后,最好先写个测试方法,用main或junit工具都成,看看你的调用poi的逻辑有没有问题。
当以上的类及方法写完后,就要在你的appfuse工程中找displaytag.properties文件了,一般就在web/class/目录下,找到后,打开此文件,添加如下一段配置:
export.excel.class=org.displaytag.export.excel.ExcelHssfView1
后面一段是你的新建的类的文件的路径
因为是多国语言系统,所以最好把display_en.properties及display_zh_Cn.properties都加上.
到此就完成了,使用自己的POI来在appfuse中导出指定格式样式的excel文件.先别急噢,还有更精彩的等着你。这个时候又有一个问题来了,如果你
页面想要显示某些列表字段列,而导出的excel文件中又不出现这样的字段,又该如何处理呢,嘿嘿,请接着看下文。
如果要实现以上功能请如下操作:
1,调整页面上的displayTag标签的参数值,呵,比如:

<display:table name="testList" cellspacing="0" cellpadding="0" requestURI="" sort="list"
id="testList" pagesize="5" class="table testList" export="true"
defaultsort="1" defaultorder="descending" >
<display:caption media="excel">ExportByCommon</display:caption>
<display:column title="ID" sortable="true" media="html">
<a href="/aaa.html?id=<c:out value="${testList.id }" /> "
target="operationFrame">
<c:out value="${testList.id }" />
</a>

</display:column>
<display:column title="Status" sortable="true" media="html">
<img src="<c:out value="${testList.status}" />.gif" title="<c:out value="Status:${testList.status}" />">
</display:column>

<display:column property="remarks" escapeXml="true" sortable="true"
title="Remarks" style="word-wrap: break-word;word-break: break-all; width:90px;"/>
<display:footer media="excel">
<c:out value="${aa }"></c:out>|
<c:out value="(${bb })"></c:out>|
<c:out value="${currentDate }"></c:out>
</display:footer>
<display:setProperty name="item_name" value="Info"/>
<display:setProperty name="items_name" value="Infos"/>
<display:setProperty name="export.excel" value="true" />
<display:setProperty name="export.excel.filename" value="<%=exportFileName%>"/>
<display:setProperty name="export.csv" value="false" />
<display:setProperty name="export.xml" value="false" />
<display:setProperty name="export.pdf" value="false" />
</display:table>
</form>
注意上面用了多种配置需求,可以自已加链接,自定义导出名,自定义表头表尾,自定义是否全排序,自定义样式等,这些网上都有,就不细说了,
关键的需求点media的配置参数噢,如果media="excel"表示只在excel中显示,如果media=html表示仅在页面出现,没有此参数是两个都显示噢
其它的格式也类同设置,到此displayTag的点点心得分享与大家完毕,谢谢大家花费时间分享我的快乐!^_^
噢,上文提到中文问题,用POI后就解决了!
分享到:
评论
6 楼 cun2001 2008-07-08  
zyhalj 写道
看到你用displaytag比较熟练,想问个问题
如何禁止DisplayTag自动生成排序link的url.
我指定了display:table的
requestURI="userList.html?operation=userList"
在这个display:table所在页面我还有一个inster操作,当做完insert操作返回当前页面时operation=insert, 这时display:table会自动把排序字段的a link的url改成userList.html?operation=insert,这样肯定是不对了,我想问怎么才能禁止display自动修改排序字段的link url

谢谢


你的问题应该可以通过设置excludedParams属性来实现,如下:
<display:table htmlId="batchList" name="list"
defaultorder="descending" export="true" id="row" pagesize="15"
requestURIcontext="false"
requestURI="orgStateAction.do?method=queryOrgState"
sort="list"
excludedParams="operation"   //指定这个参数的意思说不往url后面添加,多个参数以空格分隔即可
class="table-list">
5 楼 zyhalj 2007-11-18  
看到你用displaytag比较熟练,想问个问题
如何禁止DisplayTag自动生成排序link的url.
我指定了display:table的
requestURI="userList.html?operation=userList"
在这个display:table所在页面我还有一个inster操作,当做完insert操作返回当前页面时operation=insert, 这时display:table会自动把排序字段的a link的url改成userList.html?operation=insert,这样肯定是不对了,我想问怎么才能禁止display自动修改排序字段的link url

谢谢
4 楼 wl1985 2007-11-01  
看上面的配置吧
3 楼 WinLive 2007-10-29  
怎么使用模板导出EXCEL啊?
我找了很多资料都是说:对excel的所有的格子,一个个样式的处理,
您的方法一:一种是通过指定的excel模板
具体是怎么实现的?
2 楼 wl1985 2007-08-03  
怎么你们用displayTag没有碰到这种问题么
?
1 楼 wl1985 2007-07-31  
这个贴子我在appfuse中文论坛www.pben.cn/bbs上也发表过,同步发行,接受大伙批评

相关推荐

    displaytag1.1 原碼

    在这个"displaytag1.1 原码"的压缩包中,包含了DisplayTag 1.1版本的源代码,这对于开发者深入理解其内部机制、定制功能或排查问题非常有帮助。 DisplayTag 1.1主要知识点包括: 1. **标签库**:DisplayTag不是一...

    displaytag1.1.jar 强大标签

    displaytag1.1显示排序分页导出自动标签

    displaytag-1.1.rar_displaytag

    DisplayTag 1.1是该库的一个版本,其源码对于理解内部工作原理和自定义功能非常有价值。 在DisplayTag中,"src"标签通常指的是表格数据的来源。它允许开发者指定一个数据源,如JavaBean、List、Map或其他集合对象,...

    displaytag-1.1 源码

    6. `displaytag-doc`: 这里可能包含Displaytag的用户手册、API文档或者开发者指南,对于学习和使用Displaytag非常重要,因为它提供了详细的使用方法和最佳实践。 7. `displaytag`: 最后,这个目录很可能包含了...

    displaytag-1.1-src.zip_TableDecorator java_displayt_displaytag_d

    DisplayTag 1.1是这个库的一个版本,其源代码可以在`displaytag-1.1-src.zip`中找到,这给开发者提供了深入学习和自定义的机会。 DisplayTag的核心功能包括: 1. **分页**:DisplayTag自动处理数据的分页,无需在...

    分页用displaytag-portlet-1.1jar包

    Displaytag-portlet-1.1.jar 文件包含了DisplayTag Portlet 1.1的所有类和资源,是使用该库进行开发时需要引入的依赖。它提供了portlet环境下所需的特定功能,例如与portlet容器的集成,确保在portlet环境中正确显示...

    displaytag-1.1.jar

    displaytag-1.1.jar,显示表格的tag

    DISPLAYTAG1.1

    JSP 分页 排序 把DISPLAYTAG的JAR包导入工程,就可以实现他的功能了

    displaytag-1.1.jar和display-export-poi-1.1.jar下载

    在使用displaytag-1.1.jar和display-export-poi-1.1.jar时,首先需要将它们添加到项目的类路径中,通常是通过Maven或Gradle等构建工具管理依赖。然后在JSP页面中,可以使用DisplayTag提供的标签来创建和配置表格。...

    displaytag-1.1-bin.zip_Table_display_displaytag_displaytag-bin

    4. **自定义样式和模板**:DisplayTag使用JSP标签来创建表格,允许开发者通过CSS来控制表格的外观和布局。这使得你可以根据项目需求轻松定制表格样式。 5. **扩展性**:DisplayTag设计为可扩展,允许开发人员通过...

    displaytag标签的使用

    在配置方面,DisplayTag 使用了两个标签库:displaytag-1.1.tld 和 fmt.tld。displaytag-1.1.tld 是 DisplayTag 自身的标签,而 fmt.tld 标签库主要用于支持中文显示。如果你的项目使用的是 Servlet 2.4 之前的版本...

    displayTag学习总结(非常详细,带实例)

    displayTag 1.1 学习总结(非常详细,带实例) 绝对的好东西,如果觉得不值,可以回贴骂我!

    displaytag的使用方法

    在本文中,我们将详细讨论 Displaytag 1.1 版本的使用方法。 **一、Displaytag 安装** 首先,你需要从官方或者其他可靠的来源下载 `displaytag-1.1-bin.zip` 文件。解压后,将 `displaytag-examples-1.1.war` 中的...

    自己整理的DisplayTag标签的使用

    其中,`displaytag-1.1.tld`是DisplayTag的官方标签库,而`fmt.tld`则主要用于处理中文显示问题。 #### 构造与传递数据列表 DisplayTag从`request`或`session`范围内获取数据列表,这些数据必须来源于`List`类型。...

    displaytag-portlet-1.1.jar

    这是分页用的displaytag-portlet-1.1.jar。很高兴与大家分享!

    displaytag的使用指南(全)

    ### DisplayTag 使用指南详解 #### 一、简介 DisplayTag 是一个开源的 Java Web 标签库,主要用于处理数据表格的展示与交互。它能够帮助开发者轻松地将 JavaBean 集合转换成 HTML 表格,并且支持排序、分页等功能...

    displaytag及使用方法

    接着,在`web.xml`配置文件中注册DisplayTag的标签库描述符,这样就可以在JSP页面中使用DisplayTag的标签了。 以下是一些常见的DisplayTag使用方法: 1. **显示表格**: 使用`&lt;display:table&gt;`标签来创建表格,...

    displaytag简明使用示例

    下面我们将详细探讨DisplayTag的使用方法。 1. **基础使用** 最简单的使用方式是不使用`&lt;display:column/&gt;`标签。只需将List对象赋值给request,然后在页面上使用`&lt;display:table name="test" /&gt;`标签,DisplayTag...

Global site tag (gtag.js) - Google Analytics