`
lion222
  • 浏览: 125157 次
  • 来自: ...
文章分类
社区版块
存档分类
最新评论

extremetable入门学习笔记

阅读更多

原本准备学习displaytag的,可无意中发现了extremetable,据说比displaytag好用。所以,就决定亲自试试看。

extremetable是什么,google一下,就可以找到很多。我个人觉得,extremetable就是个在jsp中非常好用的table的taglib。

有关extremetable的入门资料,网上很多,可根据那些资料,我在尝试运行extremetable中的demo范例,都没有成功,至少是不完全成功,比如有问号只有的乱码问题等等。

我也google了很多,觉得“也来介绍一下extremetable”和“eXtremeComponent参考文档”还是很不错的,值得参考,尤其是后者,它也是extremetable的中文参考文档,尽管不全面,但对于英文不好的来说,已经是当前最全面的参考资料了。

下面是我成功运行了demo范例的步骤,尽管其中的原理还不是十分了解,但已经可以成功运行了。

环境:

tomcat:最好用tomcat-5.0.28版本的,5.5版的,需要java5,6.0版的,很少用

Eclipse:我用的是3.2版

MyEclipse:我用的是5.1版

尽管Eclipse和MyEclipse不是必须的,但对于像我这样不太熟练的人来说,可以节省很多工作。

Step1:

首先要下载extremetable包。下载地址:http://sourceforge.net/projects/extremecomp/

Step2:

启动MyEclipse,新建一个web工程,比如MyExtremeTable

Step3:

切换到MyExtremeTable工程的WebRoot\WEB-INF目录下,新建lib和tld俩个目录

Step4:

从extremetable包的dist目录下,拷贝extremecomponents.tld到新建的tld目录下

Step5:

从extremetable包的dist目录下,拷贝extremecomponents-1.0.1.jar到新建的lib目录下;并从extremetable包的lib的minimum目录下,拷贝多有jar文件到新建的lib目录下。

如果想尝试extremetable的导出功能,还需要把pdf和xls目录下的jar文件也拷贝的新建的lib目录下。

Step6:

把extremetable包image目录整个拷贝到新建web工程的WebRoot目录下,也就是与WEB-INF目录同级。

Step7:

把extremetable包的test目录下的test.jsp拷贝到WebRoot目录下。

Step8:

切换到MyEclipse,刷新MyExtremeTable工程,刷新后的MyExtremeTable工程目录结构,类似于下图:

Step9:

打开web.xml文件,添加有关tld的配置,修改后的web.xml内容,如下:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" 
    xmlns
="http://java.sun.com/xml/ns/j2ee" 
    xmlns:xsi
="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation
="http://java.sun.com/xml/ns/j2ee 
    http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
>
    
<jsp-config>
        
<taglib>
            
<taglib-uri>/WEB-INF/tld/extremecomponents.tld</taglib-uri>
            
<taglib-location>/WEB-INF/tld/extremecomponents.tld</taglib-location>
        
</taglib>
                     
</jsp-config>
</web-app>

Step10:

打开test.jsp文件,在文件开头,添加如下一句:

%@page pageEncoding="gb2312" contentType="text/html; charset=gb2312"%

可能有的系统不需要增加这句,但我的系统就是不行,没有这句的话,表头中的内容是问号。可能因为我的系统的中文的。应该可以在tomcat的配置中可以修改,还没试。

Step11:

配置tomcat。在MyEclipse中,右键MyExtremeTable,选择MyEclipse->Add and Remove Project Deployments,弹出对话框,添加tomcat,使tomcat指向你的tomcat所在的路径。

Step12:

编译工程。如果不是自动编译的话,请手动编译整个web工程。如果顺利的话,打开tomcat的webapp目录,应该可以看到MyExtremeTable文件夹以及内容。这就说明web工程已经发布到tomcat了;如果没有,可以打开Step11中的对话框,手动发布到tomcat。

Step13:

启动tomcat,然后开发浏览器,输入http://localhost:8080/MyExtremeTable/test.jsp

,其中MyExtremeTable为web工程名,可以根据实际情况修改。回车后,应该可以看到类似如下图所示的页面内容:

恭喜,已经成功了!

 

------------------------------------------------------------------------------

0.概述

    Home Page:http://www.extremecomponents.org

     Extreme Table是最功能强大而又容易配置,扩展,自定义的Table 控件。

     最紧要的功能包括排序, 分页, 导出Excel, pdf和汇总。

     springside的best 示例代码在: listBook.jsp和listOrder.jsp.

基础读物: 

     1. ExtremeTable自带的文档 .

     2.Luck翻译的ExtremeTable官方文档中文版   

1. 安装

1.1 安装原始版本

     1. 从http://www.extremecomponents.org 下载最新版

     2.把extremecomponents.jar 放入web-inf/lib

     3.根据minum, 导出excel 或 导出pdf的需要,把/lib下的jar copy到web-inf/lib

     4.把images里的图片放入web的任意目录

     5.把css文件放到web的任意目录

     6.在/source/org/extremecomponents/table/core目录找到extremetable.properties文件,把它复制到WEB-INF/classes里面并进行修改.

     7.修改web.xml (见2)。

 0.2 复制SpringSide的样式

     1.Copy springside的Table Head的图,查。

     2.将springside中的修改版extremecomponents.css文件放入任意目录

     3.把/src/resource/extremetable.properties 复制到对应目录

0.3 使用Compact View很重要

     默认的式样不符合大家的审美,幸亏还有Compact View和css设置,让我们可以敬谢不敏它号称非常方便的HtmlView子类扩展。

    1. 在全局设置里

 
table.view.html=org.extremecomponents.table.view.CompactView

    2.把images里/table/compact/*.gif copy 到 /table

2.全局属性配置

   ExtremeTable支持在properties文件里方便的统一配置丰富的全局属性

  在/source/org/extremecomponents/table/core目录找到extremetable.properties文件,把它复制到WEB-INF/classes里面.

 在web.xml里面增加

   <context-param>
        <param-name>extremecomponentsPreferencesLocation</param-name>
        <param-value>/extremetable.properties</param-value>
   </context-param>

一般只写需要修改的文件:

table.filterable=false
table.imagePath=/images/table/*.gif
table.locale=zh_CN
table.view.html=org.extremecomponents.table.view.CompactView
row.highlightRow=true
column.format.date=yyyy-MM-dd
column.format.currency=###,###,###,###,#00.00

3.导出Excel

    注意Excel 导出的Tag已改为,且官方版不支持中文文件名。

    <ec:exportXls fileName="BookList.xls" tooltip="导出 Excel"/>

在web.xml必须加入:

    <filter>
        <filter-name>eXtremeExport</filter-name>
        <filter-class>org.extremecomponents.table.filter.ExportFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>eXtremeExport</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>

     ExtremeTable导出的一项重要特性是可以根据不同的View导出不同的列.

     比如html管理界面可能只列出订单几个最重要的列,而导出excel时则需要导出所有的列。

<ec:column property="orderdate" title="订单日期"  cell="date" format="yyyy-MM-dd"  viewsDenied= "html"/>

又比如有些操作按纽的列只想在html出现,excel里不想出现:

<ec:column property="orderdate" title="订单日期" viewAllowed= "html"/>

     以上订单日期列在html view看不到,而excel,pdf view可以见到.

    而"编辑图标","选择Checkbox"这些管理界面上的列,也可以设置不export到pdf,excel view

4.其他要点

4.1. 使用排序功能时,如果property为嵌套属性时,需要设置alias

          因为javascript的关系.

<ec:column property="customer.name" title="客户名称" alias="customer"/>

4.2. Date Cell与NumberCell 和RowCountCell

     在全局属性定义:

 

 column.format.date= yyyy-MM-dd
column.format.currency= ¥###,###,#00.00
<ec:column property="totalprice" title="总金额" cell="currency" width="80" />
<ec:column property="shipdate" title="发货日期"  cell="date" width= "80"/>
<e

其中RowCountCell用于显示序号。

4.3. 汇总

在column中加入两个cac属性,就会自动在table的底端显示汇总

 

<ec:column property="totalprice" title="总金额" cell="number" format="###,###,##0.00" calc="total" calcTitle= "汇总:"/>

4.4 i18N

在Web.xml里面指定i18N的Properties文件

<context-param>
  <param-name>extremecomponentsMessagesLocation</param-name>
  <param-value>messages</param-value>
</context-param>
<ec:column property="name" title="book.name"/>

4.5数据库分页

 EC默认从数据库中查找所有记录然后由它来分页,如果查询结果较大,可以考虑使用数据库端分页的方案。

 此时,EC会使用Limit对象向Controller传递PageNo,PageSize,OrderBy等分页信息。而服务端将向EC返回总记录数和当前页的内容,具体请参看 BookController。

4.6不显示导出excel及分页

最快的方式是设置table的showStatusBar= false

<ec:table  items= "order.orderItems"var="item" action=""   showStatusBar= "false">

    4.7ImagePath

  旧版EC包括其文档都在每个table tag里定义ImagePath, 新版已经可以自动插入ContextPath,只需在properties文件定义table.imagePath=/images/table/*.gif即可

5.自定义及扩展

   ExtremeTable比Display Tag的i一个就是良好的自定义和扩展能力,不用千人一面。
   不过,人总是懒的,虽然扩展子类很容易,但能不扩展就还是不可扩展了。幸亏用Compact View再改改CSS一般就能达到要求。

 5.1. 良好的CSS定义

         ExtremeTable 的CSS定义非常严谨, 并且提供很多个层次的修改方式:

         1.直接修改css文件, 可以把table view改成任意样式

         2.修改全局属性, 改变某种元素对应的css class名

table.styleClass=tableRegion

         3.在某个页面的row,column tag中定义class

 <ec:row style="" or styleClass=""/>

        SpringSide采用层次1, 直接修改extremecomponents.css为合适的样式

5.2方便的<tr><td>属性扩展

        row与column已提供了丰富的普通属性与 javascript属性如onClick(), 如果属性仍然未够,可自行扩展<row>与<column>tag ,并通过全局属性指定新的子类名。

   为了方便大家在子类扩展属性, extreme Table提供了专门的回调函数与Util函数如

public void addColumnAttributes(Column column) {
   column.addAttribute("customAttributeOne", customAttributeOne);
}   

        

详细请看手册,Table, Row,Column都提供相同的扩展:
http://extremecomponents.org/wiki/index.php/Column#Extended_Attributes

如果不是Extremetable的特别支持, 普通taglib class要扩展属性的话:
        1.定义真正的Java属性,setter,getter
        2. tld文件中声明新的属性
        3.重载输出函数将新属性打印出来

5.3 扩展HTMLView,cell 等显示组件

     Extreme Table在这些类的扩展上放便很多,但这个版本里我还没有进行尝试,就不写了。请自行参考官方文档:http://extremecomponents.org/wiki/index.php/Html_View_Tutorial .

分享到:
评论

相关推荐

    eXtremeTable中文文档

    **eXtremeTable中文文档** eXtremeTable是一个高性能、可扩展的表格存储系统,主要用于处理大规模数据。这个系统的设计目标是提供快速的数据访问和处理能力,以适应大数据时代的挑战。它融合了数据库管理和分布式...

    eXtremeTable中文文档.pdf

    根据提供的文档部分内容,我们可以推断出这是一篇关于 eXtremeTable 的中文文档,主要涉及该工具或系统的使用、配置以及相关技术...为了更好地利用这一强大工具解决实际问题,建议深入学习其提供的官方文档和技术资料。

    eXtremeTable

    eXtremeTable文档 eXtremeTable文档 eXtremeTable文档 eXtremeTable文档 eXtremeTable文档 eXtremeTable文档

    ExtremeTable

    博文链接:https://xinzhiz.iteye.com/blog/198102

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

    开发者可以通过阅读和学习这些代码,了解如何在自己的应用程序中集成eXtremeTable,实现相同或类似的功能。源代码通常会包含以下几个部分: - 数据获取与分页逻辑:这部分代码负责从数据库或其他数据源获取数据,并...

    eXtremeTable的使用方法

    我也刚开始看,感觉是个好东东,大家多多交流

    extremeTable

    ### extremeTable:强大的数据展示工具 #### 一、概述 **extremeTable**是一款开源的JSP自定义标签库,其主要功能是通过表格形式来高效地展示数据。这款工具的最新版本为1.0.1-M1。作为一款类似于`displaytag`和`...

    eXtremeTable参考文档.pdf

    《eXtremeTable参考文档》是针对eXtremeComponents中的一款核心组件——eXtremeTable的详细...通过深入学习和实践《eXtremeTable参考文档》,开发者可以提升其在Web前端开发领域的专业技能,创造出更优质的用户体验。

    hibernate + extremetable 实现分页

    本教程将详细讲解如何使用Hibernate ORM框架结合ExtremeTable实现高效的分页查询。 Hibernate是一个强大的对象关系映射(ORM)框架,它允许开发者以面向对象的方式处理数据库操作,避免了直接编写SQL语句的繁琐。而...

    extremetable教程.pdf

    《eXtremeTable教程详解》 eXtremeTable是一款强大的开源JSP定制标签库,主要用于在Web应用中以表格形式展示数据。本教程详细介绍了eXtremeTable的配置、使用方法以及各种标签的功能,旨在帮助开发者充分利用其功能...

    eXtremeTable的使用方法.rar

    **eXtremeTable** 是一个高性能、轻量级的表格处理库,它为Java开发者提供了强大而灵活的表格数据管理能力。这个压缩包...通过深入学习提供的文档,你可以充分利用它的特性,提高开发效率并提升应用性能。

    jmesa学习笔记。。。

    ### JMesa 学习笔记详解 #### 一、概述 JMesa是一款强大的表格控件工具,主要用于Web应用程序中实现高效的数据展示与管理。本篇学习笔记主要围绕JMesa的安装配置、基本使用方法以及常见问题解决策略进行详细介绍。...

    displayTag,extremeTable

    displayTag,extremeTable相关文章

    eXtremeTable使用指南

    ### eXtremeTable使用指南:深入理解与配置 #### 引言 eXtremeTable作为eXtremeComponents系列中的核心组件之一,专为高级数据展示而设计,尤其适用于表格形式的数据呈现。该开源项目由Jeff Johnston领导的ECCN...

    springmvc+hibernate+extremetable 数据库增删改查

    Spring MVC、Hibernate 和 ExtremeTable 是三个在Web开发中常见的技术框架,它们分别负责不同的职责,协同工作以实现高效的数据管理。下面将详细解释这三个技术及其在数据库增删改查中的应用。 Spring MVC 是一个...

    eXtremeComponents-1.0.4+extremetable使用手册+需要的jar包

    eXtremeTable分页控件完整例子包括了数据的分页、数据的Excel格式导出、数据的pdf电子书格式导出、数据的文本文件格式导出等功能,里面的源代码写得非常详细,好好看一下.... 功能强大,易于扩展的extremetable就是个...

Global site tag (gtag.js) - Google Analytics