ExtJS中的表格功能非常强大,包括了排序、缓存、拖动、隐藏某一列、自动显示行号、列汇总、单元格编辑等实用功能。
表格由类Ext.grid.GridPanel定义,继承自Panel,其xtype为grid。ExtJS中,表格Grid必须包含列定义信息,并指定表格的数据存储器Store。表格的列信息由类Ext.grid.ColumnModel定义、而表格的数据存储器由Ext.data.Store定义,数据存储器根据解析的数据不同分为JsonStore、SimpleStroe、GroupingStore等。
我们首先来看最简单的使用表格的代码:
复制代码 代码如下:
Ext.onReady(function(){
var data=[ [1, 'EasyJWeb', 'EasyJF','www.baidu.com'],
[2, 'jfox', 'huihoo','www.'],
[3, 'jdon', 'jdon','s.'],
[4, 'springside', 'springside','tools.'] ];
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
});
});
执行上面的代码,可以得到一个简单的表格,如下图所示:
上面的代码中,第一行“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.baidu.com'],
[2, 'jfox', 'huihoo','www.'],
[3, 'jdon', 'jdon','s.'],
[4, 'springside', 'springside','tools.'] ];
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的属性,表示该列可以排序,执行上面的代码,我们可以得到一个支持按“项目名称“或“开发团队”的表格,如图xxx所示。
(按项目名称排序)
(可排序的列表头后面小按钮可以弹出操作菜单)
(可以指定隐藏哪些列)
另外,每一列的数据渲染方式还可以自己定义,比如上面的表格中,我们希望用户在表格中点击网址则直接打开这些开源团队的网站,也就是需要给网址这一列添加上超级连接。下面的代码实现这个功能:
复制代码 代码如下:
function showUrl(value)
{
return ""+value+"";
}
Ext.onReady(function(){
var data=[ [1, 'EasyJWeb', 'EasyJF','www.baidu.com'],
[2, 'jfox', 'huihoo','www.'],
[3, 'jdon', 'jdon','s.'],
[4, 'springside', 'springside','tools.'] ];
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
});
});
[html]
上面的代码跟前面的示例差别不大,只是在定义“网址”列的时候多了一个renderer属性,即{header:"网址",dataIndex:"homepage",renderer:showUrl}。showUrl是一个自定义的函数,内容就是根据传入的value参数返回一个包含<a>标签的html片段。运行上面的代码显示结果如下图所示:
自定义的列渲染函数可以实现在单元格中显示自己所需要的各种信息,只是的浏览器能处理的html都可以。
除了二级数组以外,表格还能显示其它格式的数据吗?答案是肯定的,下面假如我们的表格数据data定义成了下面的形式:
[code]
var data=[{id:1,
name:'EasyJWeb',
organization:'EasyJF',
homepage:'www.baidu.com'},
{id:2,
name:'jfox',
organization:'huihoo',
homepage:'www.'},
{id:3,
name:'jdon',
organization:'jdon',
homepage:'s.'},
{id:4,
name:'springside',
organization: 'springside',
homepage:'tools.'}
];
也就是说数据变成了一维数组,数组中的每一个元素是一个对象,这些对象包含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
});
上面的代码得到的结果与前面的一样。当然,表格同样能显示xml格式的数据,假如上面的数据存放成hello.xml文件中,内容如下:
复制代码 代码如下:
<?xml version="1.0" encoding="UTF-8"?><dataset> <row> <id>1</id> <name>EasyJWeb</name> <organization>EasyJF</organization> <homepage>www.baidu.com</homepage> </row> <row> <id>2</id> <name>jfox</name> <organization>huihoo</organization> <homepage>www.</homepage> </row> <row> <id>3</id> <name>jdon</name> <organization>jdon</organization> <homepage>s.</homepage> </row> <row> <id>4</id> <name>springside</name> <organization>springside</organization> <homepage>tools.</homepage> </row> </dataset>
为了把这个xml数据用ExtJS的表格Grid进行显示,我们只需要把store部分的内容调整成如下的内容即可:
复制代码 代码如下:
var store=new Ext.data.Store({
url:"hello.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:"hello.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()是用来加载数据,执行上面的代码产生的表格与前面的完全一样。
相关推荐:
了解SEO:让你的网站在搜索引擎中脱颖而出的秘密武器,宝山区常见网站优化
如何用AI写公众号文章?让创作更高效、更轻松
OpenAIGPT:开启智能时代的语言革命,ai辣妹动漫
ChatGPT无服务:如何突破限制,未来人工智能的新可能,ai绘制装饰画
seo该从什么开始,seo是什么时候开始的 ,ai写作免费英文怎么说
Zkept:重塑未来生活的智能科技革新,营销推广的面试问题
Chato1免费么?揭开这款AI聊天机器人的神秘面纱,交个朋友ai写作
“更加通顺”-让生活与工作无缝衔接的语言魅力,SEO书架书桌收纳
优化投入,让企业更具竞争力,怎样推广营销方案
WP原创:打造属于你的独特网站,从这里开始!,一个网站推广一个月需要多少钱
AI免费文章生成器:轻松创作高质量内容的终极工具
ChatGPT中文版下载,开启智能对话新体验,婚纱ai男
二创AI:打破创意壁垒,引领未来内容创作新潮流,背影教案网站建设游戏
什么是seo概念,什么是seo,sem ,ai音标谐音
seo网站是什么东西,seo网站是什么东西啊 ,ai锯齿消失
SEO是如何推动企业增长的关键力量,深圳罗湖网站建设设计
SEO埋词技巧,如何提升网站排名?,贵州营销推广方法
ChatGPT最近不好用了?了解这些背后的原因与解决方案,ai sketcher
ChatGPT,您的银行卡被拒绝了?别慌,这些方法帮您快速解决问题!,ai给那个标声调
UCMS:引领智慧医疗新时代,打造数字化健康未来,推广工作谈营销
AI写作免费一键生成下载,助您轻松创作!
文字生成AI开启创作的新纪元
SEO模块:提升网站排名,驾驭数字营销未来,营口网站建设制作平台
ChatGPT您的应用遇到问题,无法正常启动?如何解决并重新体验智能助手的魅力!,男头ai关键词
怎么使用AI生成文章,轻松提升写作效率!
什么是SEO可以自学吗,seo零基础可以自学吗 ,ai1紫
SEO应该如何提升网站流量与排名?揭秘成功的SEO策略,肺炎疫苗推广营销
SEO出超:如何通过精准优化实现网站流量大爆发,营销推广方式联系f火15星
ChatGPT的诞生,预示着人工智能大规模应用的时代已经来临,ai此生不渝
为什么说seo这么重要,seo重要吗 ,ai19920403
SEO网:让你的数字营销更加精准高效,开启网络引流新时代,丰县互联网网站推广优势
一键创作,助你轻松实现创意梦想,最低价刷粉网站推广
什么是神马排名?让你的网站脱颖而出,轻松占据搜索引擎的C位!,乳山网站优化关键词排名
SEO学堂:开启数字营销新时代,全面提升网站排名与流量,文山ai营销推广方案
SEO网络营销:如何通过精准优化提升品牌价值,青州建设网站电话
AI免费生成文章的软件:轻松创作的秘密武器
2025百度收录优化:提升网站排名,助力企业数字化转型,第一ai做
SEO能给企业带来什么价值,seo的影响 ,ai蓝衣美女
seo稿件是什么意思,seo文章写作要求 ,ai写作未来展望和展望
AI文章精简-高效提炼与优化你的内容创作,ai quid
AI缩短短文-提升创作效率,写作新体验,光速写作业ai写作app
SEO大量优化:如何通过精准策略提升网站流量,突破搜索引擎排名瓶颈,吕梁本地网站推广平台
什么是seo方法,何为seo ,ai写作神器源码是什么
不利于seo是什么,不属于seo对网店推广的作用 ,ai渐变下载
seo用什么手法,seo方式 ,ai绘画飞翔
SEO韩国:为您开启国际市场的增长之门,seo文章标题有哪些
为什么seo推广那么多,seo推广难吗 ,东莞ai听译平台
SEO留痕:数字营销的隐性力量,如何通过SEO优化让品牌更具竞争力,铁岭网站关键词建设优化
怎么让AI写文章,轻松实现内容创作的智能化
如何选择适合你的AI工具?全面解析AI工具哪个好用