ExtJS 配置和表格控件使用.docx_第1页
ExtJS 配置和表格控件使用.docx_第2页
ExtJS 配置和表格控件使用.docx_第3页
ExtJS 配置和表格控件使用.docx_第4页
ExtJS 配置和表格控件使用.docx_第5页
已阅读5页,还剩12页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

ExtJS 配置和表格控件使用ExtJS是一套AJAX控件,本人认为,它是目前我见过最好最美的JS控件库,所以非常有学习和使用价值,如果你还没有接触过ExtJS或者压根对其不感 兴趣,那么没有必要看下去了。ExtJS是一套完整的RIA解决方案,也因为功能完整造成了ext-all.js有400多k,由于是基于JS和CSS的功能实现,对客户端机器性能也 有一定的要求,即不支持IE6以下的版本。如果您的项目对网页响应时间有严格的限制,或者客户端操作系统过于陈旧,一定不要选择ExtJS。 本 文主要是介绍ExtJS的下载和配置以及一些简单的使用方法。目前最新版本为3.0,但是本文主要介绍2.2版本。 一、 ExtJS下载以及配置 1、下载地址:/(这是官网,大家可以选择自己喜欢的版本下载) 2、 配置过程,假设下载后的目录为Ext,我们在该目录下建立我们自己的目录MyExample(该目录用于存放你自己写的代码),配置过程如下: (1) 新建一个页面文件Helloworld.html (2) 在和之间添加如下代码: 代码如下: Ext.onReady(function() Ext.MessageBox.alert(HelloWorld,Hello World); ) (3) 这里注意不能用取代 (4) js的导入顺序不要更改 (3) 如果弹出一个HelloWorld的对话框,则代表配置成功。 二、表格控件Grid 的使用 EXT中的表格功能非常强大,包括排序、缓存、拖动、隐藏某一列、自动显示行号、列汇总、单元格编辑等使用功能。我们 首先介绍如何制作一个简单的Grid。 1、创建表格的列信息: 代码如下:var cm=new Ext.grid.ColumnModel( header:编号,dataIndex:id, header:名称 ,dataIndex:name, header:描述,dataIndex:desn ); 2、添加数据信息: 代码如下:var data= 1,name1,desn1, 2,name1,desn1, 3,name1,desn1, 4,name1,desn1, 5,name1,desn1 ; 3、创建数据存储对象: 代码如下:var ds=new Ext.data.Store( proxy:new Ext.data.MemoryProxy(data), reader:new Ext.data.ArrayReader(, name:id, name:name, name:desn ) ); ds.load();/这个相 当的重要 . 4、表格的列模型定义好了,原始数据和数据的转换也已经完成,剩下的只需要把它们装配在一起,我们的Grid 就创建成功了。 代码如下:var grid=new Ext.grid.GridPanel( renderTo:grid, store: ds, height:600, cm:cm ); 5、注 意:Ext.grid.Grid的renderTo属性指示EXT将表格渲染到什么地方,所以,在HTML里应该有一个与之对应。 6、所有代码清单如下(已通过测试): 代码如下: Grid 实验 效果图如图1所示 图1 一个简单的Grid 三、表格控件Grid的功能详解 第二 部分简单介绍了如何创建简单的Grid,本章将对Grid的功能进行详细的分析。 3.1 部分属性功能 1、默认情况下,Grid是可 以拖放列,也可以改变列的宽度,如果要禁用这两个功能,在定义Grid对象时分别设置enableColumnMove和 enableColumnResize为false即可。 2、如果希望显示斑马线效果,可以加上stripeRows:true 3、 Grid还支持一种读取数据时的遮罩和提示功能,设置属性loadMask:true,在store.load()完成之前一直会显 示Loading 3.2 自主决定每列的宽度 1、如果要定义宽度,只要设置该列的width属性即可,如下面的代码所示。效果 图如图2所示。 代码如下:var cm=new Ext.grid.ColumnModel( header: 编号,dataIndex:id,width:60, header:名称 ,dataIndex:name,width:180, header:描述 ,dataIndex:desn,width:200 );图2 自定义每列的宽度 2、这样需要自己去计算每列的宽度,如果想让每列自动填满Grid,只需要 viewConfig中的forceFit即可。使用forceFit后,Grid会根据你在cm里设置的width按比例分配,非常智能。实现代码如 下: 代码如下:var grid=new Ext.grid.GridPanel( renderTo:grid, stripeRows:true,/斑马线效果 loadMask:true, store: ds, height:600, cm:cm, viewConfig: forceFit:true ); 3、 我们也可以考虑autoExpandColumn,它可以让指定列的宽度自动伸展,从而填充整个表格。代码如下 代码如下:var grid=new Ext.grid.GridPanel( renderTo:grid, stripeRows:true,/斑马线效果 loadMask:true, store: ds, height:600, cm:cm, autoExpandColumn:desn / viewConfig: / forceFit:true / ); 注意:autoExpandColum只能指定一列的 id,注意,必须是id,原来我们设置的cm里面都没有id,现在为了使用autoExpandColumn,要给cm的desn设置id.于是在渲染时 desn就可以自动延伸,否则会出错。 代码如下:var cm=new Ext.grid.ColumnModel( header: 编号,dataIndex:id,width:60, header:名称 ,dataIndex:name,width:180, id:desn,header:描述 ,dataIndex:desn,width:200 ); 3.3 让Grid支持按列排序 在 EXT中可以很方便地实现排序功能,只需要在定义列模型时增加sortable属性,如下面代码所示: 代码如下:var cm=new Ext.grid.ColumnModel( header: 编号,dataIndex:id,width:60,sortable:true, header:名称 ,dataIndex:name,width:180, id:desn,header:描述 ,dataIndex:desn,width:200 ); 效果图如图3所示 图3 按列排序效果 3.4 显示时间类型数据 尽管返回的JSON里都是 数字和字符串,但是在EXT中我们同样可以从后台取得日期类型的数据,然后交给Grid进行格式化。 1、首先定义一组数据,其中最后一列是日期 格式的数据。 代码如下:var data= 1,name1,desn1,2009-09-17T02:58:04, 2,name2,desn1,2009-09-17T02:58:04, 3,name3,desn1,2009-09-17T02:58:04, 4,name4,desn1,2009-09-17T02:58:04, 5,name5,desn1,2009-09-17T02:58:04 ; 2、接着我们在reader里面增加一行配置,除了设置name以外,还设置了type和 dateFormat两个属性。代码如下: 代码如下:var store1= new Ext.data.Store( proxy:new Ext.data.MemoryProxy(data), reader:new Ext.data.ArrayReader(, name:id, name:name, name:desn, name:date,type:date,dateFormat:Y-m-dTH:i:s ) ); 3、同样的,我们还需要在cm里面增加一行配置: 代码如下:var cm=new Ext.grid.ColumnModel( header: 编号,dataIndex:id,width:60,sortable:true, header:名称 ,dataIndex:name,width:180, id:desn,header:描述 ,dataIndex:desn,width:200, header:时间 ,dataIndex:date,type:date,renderer:Ext.util.Format.dateRenderer(Y年 m月d日) ); 4、代码详细信息如下所示,效果图如图4所示。 代码如下: Grid 图4 具有时间数据的Grid 3.5 自动显示行号和复选框 实际上,行号和复选框都是 renderer的延伸。当然,复选框的功能要复杂得多。 1、自动显示行号:修改列模型cm,加入RowNumberer对象; 2、 复选框:我们创建一个CheckboxSelectionModel() 3、详细代码如下,效果图如图5所示 代码如下:var sm=new Ext.grid.CheckboxSelectionModel(); var cm=new Ext.grid.ColumnModel( new Ext.grid.RowNumberer(), sm, header:编号 ,dataIndex:id,width:40,sortable:true, header:名称 ,dataIndex:name,width:180, id:desn,header:描述 ,dataIndex:desn,width:200, header:时间 ,dataIndex:date,type:date,renderer:Ext.util.Format.dateRenderer(Y年 m月d日) ); 图5 自动行号以及复选框效果图3.6 表格分页 Grid控件对性能要求较高,如果在一个Grid里面显示上千条记录,效率会有明显下降,所以必须考虑分页问题。 1、 为Grid添加分页工具条:在前面代码的基础上修改grid代码: 代码如下:var grid1=new Ext.grid.GridPanel( renderTo:grid1, stripeRows:true,/斑马线效果 loadMask:true, store: store1, height:200, cm:cm, viewConfig: forceFit:true , bbar:new Ext.PagingToolbar( pageSize:10, store: store1, displayInfo:true, displayMsg:显示第0条到1条记录,一共2条, emptyMsg: 没有记录 ) ); 2、效果图如图6所示: 图6 添加分页工具条 3、如果要真正实现分页,还需要通过后台脚本获得分页数据,这部分在此不再给出 四、 可编辑表格控件EditorGrid EditorGrid可以直接在表格里面执行添加、删除、修改、查找等功能,然后一次性保持。还有可以 动态修改某个单元格,这些单元格我们先暂时不能为空,保存时会进行检测,为空就无法保存,验证信息会给予提示。 4.1 制作一个简单的EditorGrid 1、定义列,代码如下: 代码如下:var cm=new Ext.grid.ColumnModel( header:编号 ,dataIndex:id,width:40,editor:new Ext.grid.GridEditor( new Ext.form.TextField( allowBlank:false ) ), header:名称 ,dataIndex:name,width:180,editor:new Ext.grid.GridEditor( new Ext.form.TextField( allowBlank:false ) ), id:desn,header: 描述,dataIndex:desn,width:200, header:时间 ,dataIndex:date,type:date,renderer:Ext.util.Format.dateRenderer(Y年 m月d日) ); 2、定义grid,注意此时是EditorGridPanel. 代码如下:var grid1=new Ext.grid.EditorGridPanel( renderTo:grid1, store: store1, height:200, clicksToEdit:1, cm:cm ); 3、默认情况下,需要双击单元格才能激 活编辑器,从而进行修改,不过,也可以给Grid配置clickToEdit:1,这样就可以单击单元格激活编辑器,从而进行修改,如图7所示: 图7 通过单击修改单元格 五、属性表格PropertyGrid 属性表格扩展自 EditorGridPanel,所以可以直接编辑右边的内容,注意:只有右边的,即使你单击左边的单元格,编辑器也会出现在右边。 定义的方法 如下: 代码如下: 效果图如图8所示: 六、分组表格Group 分组表格就是在普通表格的基础上,根据某一列的数据将表格中的数据分组显示的表格 控件。 1、首先定义一组数据 代码如下:var data= 1,male,name1,desn1, 2,male,name2,desn1, 3,female,name3,desn1, 4,male,name4,desn1, 5,female,name5,desn1, 6,male,name6,desn1, 7,male,name7,desn1 ; 2、创建表格的列信息 代码如下:var sm=new Ext.grid.CheckboxSelectionModel(); var cm=new Ext.grid.ColumnModel( new Ext.grid.RowNumberer(), sm, header:编号 ,dataIndex:id,width:40,sortable:true, header:性别 ,dataIndex:sex,width:180, header:名称 ,dataIndex:name,width:200, header:描述 ,dataIndex:desn,width:200 ); 3、创建数据存储对象 代码如下:var store1= new Ext.data.GroupingStore( proxy:new Ext.data.MemoryProxy(data), reader:new Ext.data.ArrayReader(, name:id, name:sex, name:name, name:desn ), groupField:sex, sortInfo:field:id,direction:ASC ); store1.load(); 4、设计分组设计表格 代码如下:var grid1=new Ext.grid.GridPanel( store: store1, height:300, cm:cm, view:new Ext.grid.GroupingView(), renderTo:grid1 ); 5、代 码清单如下,效果图如图9所示。 代码如下: 分组表格控件 图9 分组表格六、可拖放的表格首先我们看图10的效果

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论