`
menjoy
  • 浏览: 423447 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

extremeTable介绍

    博客分类:
  • Java
阅读更多

1、何为 extremeTable,又一个开源taglib
extremeTable,开源的jsp 自定义标签,以表格的形式显示数据,当前最新版本为 1.0.1-M1.
它是一个类似display tag,valueList 等开源产品.
homepage: http://extremecomponents.org/
download: http://sourceforge.net/projects/extremecomp/

开源产品作者:
Jeff Johnston ,现居住美国,圣路易斯.
六年web应用软件开发经验,eXtremeComponents最初的创建者. 负责设计及大部分的编码。

其它还包括Paul Horn ,eXtremeTree的技术设计, 以及大部分的编码;
Dave Goodin,Brad Parks等.

主要特色
1、导出EXCEL以及pdf无需再另写jsp(这个基本与valuelist作比较,因为以前用valueList的时候每写一个table都要再写一个excel.jsp)
2、扩展性比较强,基本上想怎样改就怎样改,对jar影响比较少。
3、另外据官方声称有以下四点

Fast ( 本人曾小测一次,三千纪录情况下,效率基本与valuelist持平)
Efficient
Easy ( 得确很容易使用与理解加扩展)
Reliable

安装要求
1、Servlet 2.3 或更高
2、 JDK 1.3.1 或更高
最小的Jars需求
1、commons-beanutils 1.6
2、commons-collections 3.0
3、 commons-lang 2.0
4、 commons-logging 1.0.4
5、 standard 1.0.2

PDF 导出要用到的包:
1、 avalon-framework 4.0
2、batik 1.5-fop-0.20-5
3、 fop 0.20.5
4、 xalan 2.5.1
5、 xercesImpl 2.6.1
6、 xml-apis 2.0.2
XLS 导出要用到的包:
1、 poi-2.5.1.jar


2、安装与测试

下载解压到的主要文件包括

[1]src源文件
[2]extremecomponents.jar以及其它所依赖的包

[3]tld文件
extremecomponents.tld

[4]一组默认样式及图片
extremecomponents.css

[5]用以校验安装的测试页面
test.jsp


[6]doc文档,比较详细

快速配置安装
web app目录结构
/ROOT
  /WEB-INF/web.xml
 /tld/extremecomponents.tld
/lib
/classes/extremecomponents.properties
[extremecomponents.properties文件可到source\org\extremecomponents\table\core\中得到]
 /images/*.jpg [一组默认样式及图片]
 /css/extremecomponents.css
 /test.jsp
 /index.jsp [用于学习以及扩展测试用代码请见下]

web.xml 配置
包括taglib uri 定义以及导出文件filter,由于只是手板功夫,这里就略过了,相关代码如下:

<taglib></taglib>
<taglib-uri></taglib-uri>/tld/extremecomponents
<taglib-location></taglib-location>/WEB-INF/tld/extremecomponents.tld

<filter></filter>
<filter-name></filter-name>eXtremeExport
<filter-class></filter-class>org.extremecomponents.table.filter.ExportFilter

<filter-mapping></filter-mapping>
<filter-name></filter-name>eXtremeExport
<url-pattern></url-pattern>/*


配置好所有后,开tomcat,测试浏览http://your_web_app/test.jsp,看到

Congratulations!! You have successfully configured eXtremeTable!
恭喜你,这表示安装成功!


3、动手学习这个taglib
建index.jsp页面,修改代码如下


<!---->
<!---->
<!---->
<!---->
<!---->
<!---->
<link href="&amp;lt;c:url value=" type="text/css" rel="stylesheet">">

<!---->
collection="goodss"
action="${pageContext.request.contextPath}/test.jsp"
imagePath="${pageContext.request.contextPath}/images/*.gif"
cellpadding="1"
title="my bread">
<ec:column property="code"></ec:column>
<ec:column property="name"></ec:column>
<ec:column property="status"></ec:column>
<ec:column cell="date" property="born" format="yyyy-MM-dd"></ec:column>

[1] 1.0.1-M1 版支持国际化
修改web.xml文件增加

<context-param></context-param>
<param-name></param-name> extremecomponentsResourceBundleLocation
<param-value></param-value> com.itorgan.tags.extreme.extremetableResourceBundle


意指到 com.itorgan.tags.extreme 下找 extremetableResourceBundle_[language]_[country].properties 文件

extremetableResourceBundle_en_US.properties代码如下
table.statusbar.resultsFound={0} results found, displaying {1} to {2}
table.statusbar.noResultsFound=There were no results found.
table.toolbar.showAll=Show All

extremetableResourceBundle_zh_CN.properties如下.
table.statusbar.resultsFound={0} \u6761\u7EAA\u5F55\u7B26\u5408\u6761\u4EF6, \u73B0\u5728\u662F\u7B2C {1} \u81F3 {2} \u6761\u7EAA\u5F55
table.statusbar.noResultsFound=\u6CA1\u6709\u8981\u67E5\u8BE2\u7684\u7EAA\u5F55\u3002
table.toolbar.showAll=\u6240 \u6709

补充:中文 - > Unicode编码 可通过反编译class文件或用native2ascii命令得到 。


然后在table标签中增加locale属性即可切换

………………
………………
………………
locale="en_US"
>

………………
………………
………………
locale="zh_CN"
>


[2] 保留table的上一次状态
是指,不管跳转到另一个后再返回,extremeTable会将之前的Filter,Sort参数保存到session中,以至返回看到的页面还是之前的状态.
实现操作方法:
修改extremecomponents.properties文件
table.useSessionFilterSortParam=foo
saveFilterSort="true" 注意:saveFilterSort="true"不能在properties文件中配置,只能在页面中设


  ……………………
saveFilterSort="true"
/ec:table>
跳到
新建一页面用于跳转的页面 1.jsp
代码为

[3] 样式修改
基本的HTML结构

extremeTable支持样式快速切换.可自定的样式包括column 的td以及table的一些属性,例如cellpadding等,
另本人发现,在properties中如下设置tableHeader的样式是不行的.不知道是否一个BUG
table.headerClass=itoTableHeader
table.headerSortClass=itoTableHeaderSort

只能继承一个HeaderCell

public class HeaderCell extends org.extremecomponents.table.cell.HeaderCell
{
public final static String TABLE_HEADER = "itoTableHeader";
public final static String TABLE_HEADER_SORT = "itoTableHeaderSort";

新的样式代码:


<link href="&amp;lt;c:url value=" rel="stylesheet">" TYPE="text/css">
collection="goodss"
action="${pageContext.request.contextPath}/test.jsp"
imagePath="${pageContext.request.contextPath}/images/*.gif"
cellpadding="1"
title="my bread"
saveFilterSort="true"
locale="zh_CN"
>
<ec:column title="编号" property="code" width="100" styleclass="GridTd"></ec:column>

[4] 实现 table width 自动累加
原来的extremeTable 宽度要自己set。不会自动能过下面的column累加。
本人作了个修改以达到自动累加,省得自己加写上去:
查看htmlView.java 两处地方 
toolbarPlacement
tableStart可见两处地方要修改的


[5] custom cell
在properties文件中我们可观察到:

table.cell_=display
table.cell_currency=org.extremecomponents.table.cell.NumberCell
table.cell_number=org.extremecomponents.table.cell.NumberCell
table.cell_display=org.extremecomponents.table.cell.DisplayCell
table.cell_date=org.extremecomponents.table.cell.DateCell
当 column 默认使用org.extremecomponents.table.cell.DisplayCell


public class DisplayCell extends BaseCell {

public String html() {
HtmlBuilder html = new HtmlBuilder();

html.append(startTD());

Object value = column.getValue();
if (value != null && StringUtils.isNotEmpty(value.toString())) {
html.append(value);
} else {
html.append(" ");
}

html.append(endTD());

return html.toString();
}
}

ec已其它cell
日期格式化: cell = " date " format = " yyyy-MM-dd "
数字格式化: cell="currency" format="###,###,##0.00"

另外,extremeTable支持自定义cell
在这里我以一个简单的例子[以input框的形式出现] 说明如何实现这一方便的扩展

public class DemoInput extends BaseCell
{
public String html()
{
Integer rowNum = rowcount;
HtmlBuilder html = new HtmlBuilder();
html.append(startTD());
Object value = column.getValue();
HtmlBuilder input = new HtmlBuilder();
input.input("text");
input.name(column.getProperty() + "_" + rowNum);
input.value(value.toString());
input.close();
html.append(input.toString());
html.append(endTD());
return html.toString();
}
}


properties文件增加

table.cell_demoInput =org.extremecomponents.table.cell.DemoInput
jsp代码

当然这只是一个简单的demo以说明如何自定义cell
如上面你可以简单的实现同样功能<ec:column title="编号" property="code" width="100" styleclass="GridTd">

</ec:column>
[6]Extended Attributes
新版本支持Extended Attributes,方便了用户扩展,记得0.9版本时还要我修改N个地方,现在为table,column增加attribute方便多了.
为table增加一个height的属性


public class TableTag extends org.extremecomponents.table.tag.TableTag
{
//div 的高度
private String height;

public String getHeight()
{
return height;
}

public void setHeight(String height)
{
this.height = height;
}

public void addExtendedAttributes(Attributes attributes)
{
attributes.addAttribute("height", getHeight());
}

/**//**
* set the new attribuer to null - by ito
*/
public void release()
{
super.release();
height = null;
}
}
然后就可以通过
model.getTableHandler().getTable().getAttribute("height")取得这个值.可以方便扩展.

[7] 解决excel中文问题
继承XlsView.java


private void body(BaseModel model, Column column, boolean isFirstColumn, boolean isLastColumn) {
//原来的代码略
hssfCell.setEncoding(HSSFCell.ENCODING_UTF_16); //解决中文乱码
//原来的代码略

}

private void createHeader(BaseModel model) {
//原来的代码略
hssfCell.setEncoding(HSSFCell.ENCODING_UTF_16); //解决中文乱码
//原来的代码略

}

[8] 解决pdf中文问题
帮POF注册中文字体,再修改export view即可解决

[9] Pagination

[10] 其它亮点
A sortable 与 exportable 属性 ,分别指可否排序,可否导出. 值为 false/true
B 可以直接在<ec:column></ec:column>中加html代码.
并可用{collectionName.objectName}类似的语法取得当前object的成员变量值
C ${ROWCOUNT}可取当前row num,是指以1开始计算
D ec另一亮点就帮我们写好了form ,如上代码:
<ec:form action="goods.do" name="mainform"></ec:form>设置form name以及action

参考文档
http://extremecomponents.org/extremesite/public/documentation.jsp

分享到:
评论

相关推荐

    eXtremeTable中文文档

    文档还会介绍eXtremeTable的高级功能,如数据分区策略、并发控制和负载均衡。这些特性有助于进一步提升系统的处理能力和效率。此外,关于备份与恢复、监控与日志、安全性等运维相关的知识也会在文档中得到详述,这...

    eXtremeTable中文文档.pdf

    本文档将详细介绍 eXtremeTable 的基本概念、核心功能及使用方法等,旨在帮助用户更好地理解和掌握该系统。 ### 基本概念 1. **表(Table)**:在 eXtremeTable 中,数据以表的形式组织。每个表可以包含多个字段,...

    eXtremeTable分页控件完整例子(数据分页+数据导出)

    以下是具体导出方式的介绍: 1. **Excel导出**:利用Java的Apache POI库,eXtremeTable可以将表格数据转换成Excel文件格式(.xls或.xlsx)。这种导出方式对于数据分析和报告制作非常有用,因为Excel提供了丰富的...

    ExtremeTable

    这份文档详细介绍了如何创建表格、填充数据、设置样式、处理事件等基础知识,同时也包含了高级特性的使用示例,如数据绑定、公式计算和图表绘制。 在实际应用中, ExtremeTable 可以广泛应用于企业级应用的后台系统...

    extremetable教程.pdf

    本教程详细介绍了eXtremeTable的配置、使用方法以及各种标签的功能,旨在帮助开发者充分利用其功能,实现高效、灵活的数据展示。 1. 配置 配置eXtremeTable需要满足以下先决条件: - Servlet 2.3或更高版本的服务器...

    eXtremeTable使用指南

    本文旨在详细介绍eXtremeTable的使用方法、配置流程及底层技术需求,以帮助开发者更好地理解和应用这一强大工具。 #### 版权声明与许可 遵循文档使用与传播的两项基本原则:一是不得收取任何费用;二是在任何形式...

    eXtremeComponents参考文档

    - **引言**:介绍eXtremeTable的基本概念和用途。 3. **TableTag**: - **显示图片**:说明如何在表格中嵌入和显示图像。 - **过滤、排序和动作(Action)**:提供表格数据的筛选、排序和用户操作功能。 - **...

    Springside之开发bookstore心得

    本心得将详细介绍BookStore项目的架构设计、关键技术组件以及具体实现细节。 #### 前台功能模块 - **图书浏览**:用户可以在网站上浏览各类图书信息。 - **图书查询**:用户可以根据关键词进行图书搜索。 - **...

    struts2+hibernate+spring

    - **ExtremeTable Excel/PDF导出过滤器**:提供表格数据导出为Excel或PDF的功能。 - **Spring ApplicationContext Listener**:在Web应用启动时加载Spring容器,确保Spring容器可以在应用启动时初始化。 - **Spring ...

    ECTable配置方法.txt eXtremeComponents集成方法

    本文档主要介绍了如何在项目中配置并集成eXtremeComponents框架中的ECTable组件。eXtremeComponents是一款功能强大的Java Web组件库,尤其适用于构建复杂的表格数据展示功能。通过本文档的学习,您可以了解到整个...

    jmesa使用说明文档

    **JMESA 概述** ...通过以上介绍,你应该对 JMESA 的基本使用和主要功能有了全面了解。在实际开发中,根据文档提供的信息,结合你的需求,可以灵活地集成和扩展 JMESA,实现高效的数据展示和管理。

    eXtremeComponentsEC使用总结

    该标签库的核心组件是eXtremeTable,它可以方便地将数据集(通常是Bean对象或Map集合)以表格的形式展现出来。EC不仅提供了丰富的配置选项,还支持多种数据导出格式,例如PDF和Excel。 #### 二、环境要求与特点 - ...

    jmesa学习笔记。。。

    本篇学习笔记主要围绕JMesa的安装配置、基本使用方法以及常见问题解决策略进行详细介绍。在实际项目开发过程中,作者之前使用过其前身ExtremeTable,并在使用过程中遇到了一些bug,最终决定转向JMesa。 #### 二、...

Global site tag (gtag.js) - Google Analytics