ExtJS3.0之基本表格GridPanel
ExtJS中的表格功能非常强大,包括了排序、缓存、拖动、隐藏某一列、自动显示行号、列汇总、单元格编辑等实用功能。
表格由类Ext.grid.GridPanel定义,继承自Panel,其xtype为grid。ExtJS中,表格Grid必须包含列定义信息,并指定表格的数据存储器Store。表格的列信息由类Ext.grid.ColumnModel定义、而表格的数据存储器由Ext.data.Store定义,数据存储器根据解析的数据不同分为SimpleStroe、JsonStore、GroupingStore等。
1、首先来看最简单的使用表格(SimpleStroe)的代码:
/// <reference path="vswd-ext_2.0.2.js" />Ext.onReady(function(){ var data=[ [1, 'EasyJWeb', 'EasyJF','www.easyjf.com'], [2, 'jfox', 'huihoo','www.huihoo.org'], [3, 'jdon', 'jdon','www.jdon.com'], [4, 'springside', 'springside','www.springside.org.cn'] ]; var store=new Ext.data.SimpleStore({data:data,fields:["id","name","organization","homepage"]}); var grid = new Ext.grid.GridPanel({ renderTo:"hello", title:"中国Java开源产品及团队", height:150, width:600, columns:[{header:"项目名称",dataIndex:"name"}, {header:"开发团队",dataIndex:"organization"}, {header:"网址",dataIndex:"homepage"}], store:store, autoExpandColumn:2 }); });
这个地方法应该注意,在HTML页面中有id为hello的标签,如:<div id="hello"></div>
否则将会报错:dom为空或不是对象。这个问题让我整了好久。
执行上面的代码,可以得到一个简单的表格,如下图所示:
上面的代码中,第一行“var data=…”用来定义表格中要显示的数据,这是一个[][]二维数组;第二行“var store=…”用来创建一个数据存储,这是GridPanel需要使用配置属性,数据存储器Store负责把各种各样的数据(如二维数组、JSon对象数组、xml文本)等转换成ExtJS的数据记录集Record,关于数据存储器Store我们将在下一章中作专门介绍。第三行“var grid = new Ext.grid.GridPanel(…)”负责创建一个表格,表格包含的列由columns配置属性来描述,columns是一数组,每一行数据元素描述表格的一列信息,表格的列信息包含列头显示文本(header)、列对应的记录集字段(dataIndex)、列是否可排序(sorable)、列的渲染函数(renderer)、宽度(width)、格式化信息(format)等,在上面的列子中只用到了header及dataIndex。
下面我们看简单看看表格的排序及隐藏列特性,简单修改一下上面的代码,内容如下:
Ext.onReady(function(){ var data=[ [1, 'EasyJWeb', 'EasyJF','www.easyjf.com'], [2, 'jfox', 'huihoo','www.huihoo.org'], [3, 'jdon', 'jdon','www.jdon.com'], [4, 'springside', 'springside','www.springside.org.cn'] ]; var store=new Ext.data.SimpleStore({data:data,fields:["id","name","organization","homepage"]}); var colM=new Ext.grid.ColumnModel([{header:"项目名称",dataIndex:"name",sortable:true}, {header:"开发团队",dataIndex:"organization",sortable:true}, {header:"网址",dataIndex:"homepage"}]); var grid = new Ext.grid.GridPanel({ renderTo:"hello", title:"中国Java开源产品及团队", height:200, width:600, cm:colM, store:store, autoExpandColumn:2 }); });
直接使用new Ext.grid.ColumnModel来创建表格的列信定义信息,在“项目名称“及“开发团队”列中我们添加了sortable为true的属性,表示该列可以排序,执行上面的代码,我们可以得到一个支持按“项目名称“或“开发团队”的表格,如下图所示。
(按项目名称排序)
(可排序的列表头后面小按钮可以弹出操作菜单)
(可以指定隐藏哪些列)
另外,每一列的数据渲染方式还可以自己定义,比如上面的表格中,我们希望用户在表格中点击网址则直接打开这些开源团队的网站,也就是需要给网址这一列添加上超级连接。下面的代码实现这个功能:
function showUrl(value){ return "<a href=\"http://"+value+"\" target=\"_blank\">"+value+"</a>";}Ext.onReady(function(){ var data=[ [1, 'EasyJWeb', 'EasyJF','www.easyjf.com'], [2, 'jfox', 'huihoo','www.huihoo.org'], [3, 'jdon', 'jdon','www.jdon.com'], [4, 'springside', 'springside','www.springside.org.cn'] ]; var store=new Ext.data.SimpleStore({data:data,fields:["id","name","organization","homepage"]}); var colM=new Ext.grid.ColumnModel([{header:"项目名称",dataIndex:"name",sortable:true}, {header:"开发团队",dataIndex:"organization",sortable:true}, {header:"网址",dataIndex:"homepage",renderer:showUrl}]); var grid = new Ext.grid.GridPanel({ renderTo:"hello", title:"中国Java开源产品及团队", height:200, width:600, cm:colM, store:store, autoExpandColumn:2 }); });
上面的代码跟前面的示例差别不大,只是在定义“网址”列的时候多了一个renderer属性,即{header:"网址",dataIndex:"homepage",renderer:showUrl}。showUrl是一个自定义的函数,内容就是根据传入的value参数返回一个包含<a>标签的html片段。运行上面的代码显示结果如下图所示:
自定义的列渲染函数可以实现在单元格中显示自己所需要的各种信息,只是的浏览器能处理的html都可以。
2、除了二级数组以外,表格还能显示其它格式的数据吗?答案是肯定的,下面假如我们的表格数据data定义成了下面的形式(JsonStore):
var data=[{id:1, name:'EasyJWeb', organization:'EasyJF', homepage:'www.easyjf.com'}, {id:2, name:'jfox', organization:'huihoo', homepage:'www.huihoo.org'}, {id:3, name:'jdon', organization:'jdon', homepage:'www.jdon.com'}, {id:4, name:'springside', organization: 'springside', homepage:'www.springside.org.cn'} ];
也就是说数据变成了一维数组,数组中的每一个元素是一个对象,这些对象包含name、organization、homepage、id等属性。要让表格显示上面的数据,其实非常简单,只需要把store改成用Ext.data.JsonStore即可,代码如下:
var store=new Ext.data.JsonStore({data:data,fields:["id","name","organization","homepage"]}); var colM=new Ext.grid.ColumnModel([{header:"项目名称",dataIndex:"name",sortable:true}, {header:"开发团队",dataIndex:"organization",sortable:true}, {header:"网址",dataIndex:"homepage",renderer:showUrl}]); var grid = new Ext.grid.GridPanel({ renderTo:"hello", title:"中国Java开源产品及团队", height:200, width:600, cm:colM, store:store, autoExpandColumn:2 });
上面的代码得到的结果与前面的一样。
3、当然,表格同样能显示xml格式的数据,假如上面的数据存放成dataXml.xml文件中,内容如下:
<?xml version="1.0" encoding="UTF-8"?><dataset> <row> <id>1</id> <name>EasyJWeb</name> <organization>EasyJF</organization> <homepage>www.easyjf.com</homepage> </row> <row> <id>2</id> <name>jfox</name> <organization>huihoo</organization> <homepage>www.huihoo.org</homepage> </row> <row> <id>3</id> <name>jdon</name> <organization>jdon</organization> <homepage>www.jdon.com</homepage> </row> <row> <id>4</id> <name>springside</name> <organization>springside</organization> <homepage>www.springside.org.cn</homepage> </row> </dataset>
为了把这个xml数据用ExtJS的表格Grid进行显示,我们只需要把store部分的内容调整成如下的内容即可:
var store=new Ext.data.Store({ url:"dataXml.xml", reader:new Ext.data.XmlReader({ record:"row"}, ["id","name","organization","homepage"]) });
其它的部分不用改变,完整的代码如下:
function showUrl(value){ return "<a href='http://"+value+"' target='_blank'>"+value+"</a>";}Ext.onReady(function(){ var store=new Ext.data.Store({ url:"dataXml.xml", reader:new Ext.data.XmlReader({ record:"row"}, ["id","name","organization","homepage"]) }); var colM=new Ext.grid.ColumnModel([{header:"项目名称",dataIndex:"name",sortable:true}, {header:"开发团队",dataIndex:"organization",sortable:true}, {header:"网址",dataIndex:"homepage",renderer:showUrl}]); var grid = new Ext.grid.GridPanel({ renderTo:"hello", title:"中国Java开源产品及团队", height:200, width:600, cm:colM, store:store, autoExpandColumn:2 }); store.load(); });
store.laod()是用来加载数据,执行上面的代码产生的表格与前面的完全一样。
最后要注意的是:解析XML是可以的,但是必须将项目部署在WEB服务器中,才能显示出解析出来的数据,如果只打的是静态页面,则只能看到页面表格框架,并不能得到数据。
这个不知道为什么必须部署在Web服务器中,不知道是不是必须,只是部署以后就正常读数据了。有高手知者,请留言说一下。TIA。
发表于: 2009-09-01,修改于: 2009-09-01 17:49,已浏览1346次,有评论2条 推荐 投诉
网友: 本站网友 时间:2009-09-18 10:34:36 IP地址:218.4.63.★
解析XML的xml文件的路徑是不是放錯了或是你寫的url路徑不對啊。
网友: acc 时间:2009-09-19 12:58:34 IP地址:119.120.101.★
已经找到原因了:
可以看这里:http://blog.chinaunix.net/u/22371/showart_2043667.html
因为Sote组件接受一个参数url,如果设置url,则ExtJS会创建一个与服务器交互的Ext.data.HttpProxy对象,该对象通过指定的Connection或Ext.Ajax.request来向服务端发送请求,从而可以读取到服务器端的数据。
分享到:
相关推荐
这个压缩包文件提供了EXT3.0中的几乎全部控件的演示代码,覆盖了表格、表单、分页工具栏以及图标等多个重要组件的使用方法。下面将详细介绍这些知识点。 1. 表格(Grid):EXT3.0的表格控件是其核心功能之一,能够...
1. **组件丰富**:EXT3.0包含了大量的可重用UI组件,如表格、表单、树形视图、面板、窗口、菜单等,这些组件具有丰富的样式和高度定制性。 2. **数据绑定**:EXT3.0支持数据绑定,能够将数据模型与界面组件直接关联...
例如,Ext.Component是EXT3.0的基础组件类,它包含了创建任何可视元素的基本属性和方法,如渲染、大小调整等。 2. **组件系统**:EXT3.0的核心是其组件模型,包括Grid面板、Form表单、Tree视图、Tab面板等多种组件...
Ext 3.0 中文文档Ext 3.0 中文文档Ext 3.0 中文文档Ext 3.0 中文文档Ext 3.0 中文文档Ext 3.0 中文文档Ext 3.0 中文文档Ext 3.0 中文文档Ext 3.0 中文文档Ext 3.0 中文文档Ext 3.0 中文文档
【Ext3.0使用示例】 Ext3.0是一种广泛使用的日志文件系统,它是在Linux操作系统中的标准文件系统之一。这个版本的Ext3引入了许多改进,以提高系统的稳定性和性能,尤其适合大规模数据存储和高并发访问的环境。本文...
EXT 3.0中文API是EXT JavaScript库的一个重要版本,主要为Web应用程序提供丰富的用户界面组件和交互功能。EXT 3.0的API文档对于开发者来说是不可或缺的资源,它详细解释了各种类、方法、事件和配置选项,帮助开发者...
5. **表格和数据网格**:Ext3.0的表格功能强大,支持多列排序、分页、行编辑、列隐藏等功能,数据网格则可以展示大量结构化数据,同时支持数据操作。 6. **表单组件**:丰富的表单组件,如文本框、下拉框、复选框、...
EXT3.0 alpha 版本可能是指EXT3的一个早期开发版本,通常alpha版本是软件开发过程中的第一个公开测试版本,可能存在较多bug和不稳定因素。而EXT2.21可能是EXT2文件系统的某个更新版本,EXT2是EXT3的前身,不包含日志...
Ext3.0是Ext JS框架的一个重要版本,它在Web应用程序开发中提供了强大的用户界面组件和数据管理功能。此版本的发布RC1(Release Candidate 1)意味着它已接近最终稳定版,开发者可以开始测试并为正式版做好准备。API...
4. **表格与表单**:Ext 3.0的表格组件支持分页、排序、过滤等功能,并且可以与数据存储进行深度集成。表单组件则提供了一套完整的表单元素,如文本输入框、下拉列表、复选框等,以及表单验证和提交机制。 5. **...
EXT3.0登录实例是一个典型的EXT应用场景,通过它,开发者可以学习到EXT的基本组件用法、事件处理机制以及如何结合服务器进行数据交互。掌握这些知识点,对于理解EXT框架和开发Web应用具有重要意义。
Ext3.0中文帮助手册是针对Ext JavaScript库的详尽指南,主要面向开发者,提供了关于Ext 3.0版本的API文档。这个手册是开发基于Web的富客户端应用的重要参考资料,因为Ext是一个强大的用户界面框架,它允许创建复杂的...
Ext 3.0 是一个基于 JavaScript 的开源前端框架,用于构建富互联网应用程序(RIA)。它提供了丰富的组件库,包括窗口、面板、表格、菜单等,支持数据绑定和事件驱动的编程模型,使得开发者能够创建复杂且用户友好的...
在学习EXT 3.0时,建议首先了解其基本架构和组件体系,然后深入研究具体组件的使用方法,最后结合实际项目需求进行实践。此外,理解EXT的事件驱动机制和数据绑定原理也是掌握EXT的关键。通过EXT 3.0 中文API的学习,...
1. **组件系统**:Ext 3.0提供了一套完整的组件库,包括按钮(Button)、表格(Grid)、表单(Form)、面板(Panel)等,这些组件可以灵活组合,构建出复杂的用户界面。 2. **数据绑定**:通过数据绑定,开发者可以...
这份"Ext3.0中文文档"提供了全面的指南,帮助开发者深入理解并有效利用这个框架。 一、Store:在Ext 3.0中,Store是数据管理的核心。它负责存储和管理数据,与各种UI组件(如Grids和Trees)进行交互。Store可以连接...
在深入学习EXT 3.0源码时,建议先从核心类开始,例如Ext.Element(基础DOM操作)、Ext.Panel(基本组件)和Ext.data.Store(数据管理)。了解这些基础类的用法和实现原理后,再逐步探索更复杂的组件和功能,如Grid、...
1. 基于组件的架构:Ext3.0采用模块化设计,每个UI元素都是一个独立的组件,如面板、表格、表单等,方便复用和组合,提高了开发效率。 2. 强大的数据绑定:通过Data Package,Ext3.0支持与后台数据的双向绑定,能够...
extjs3.0 ext3.0 ext文档 ext例子