- 浏览: 238425 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
q459997705:
写的很好,对我很有用
java 连接paradox数据库的几种方式 -
raisun_1988:
还不会用啊
扩展GridPanel,附带分页选中状态,实现快速构建一个功能齐全的Grid -
海阔天空shen:
貌似不行吧 一直loading
查看ext的api文档 -
fxn19870827:
好像是不行啊
jsp解决图片缓存问题 -
songs_0319:
没有用 ,在firefox里面还是乱码
设置EXT提交数据的编码
使用简单的配置就可以实现 store, columns, selModel , pagingToolbar ,
最重要的一点是实现分页时可以保持前一页的选中状态,
但是要遵守其中的一些规定,至于哪些规定呢,看下面的代码就知道啦!
代码如下:
最重要的一点是实现分页时可以保持前一页的选中状态,
但是要遵守其中的一些规定,至于哪些规定呢,看下面的代码就知道啦!
代码如下:
/* * @class Ext.ux.grid.CollectGrid * @version: 1.0 * @author: chengbao_zhu * * Example : Ext.onReady(function(){ var CM_JR_Record = [ { dataIndex:"", //the ColumnModel options alse the JsonReader mapping (required) header:"", //the ColumnModel options (required) visiable: false, //my expands option to show the header or not (options) type: date, //the type of this data (options) ...another options of ColumnModel },{ dataIndex : '', header : "", width : 130 }]; var myGrid = new Ext.ux.grid.CollectGrid({ url : 'MyJsp.jsp', // the store load url (required) CM_JR_Record: CM_JR_Record, //.....(required) rowNumber:true, //true to add a Ext.grid.RowNumberer,defalut(true) checkBox:true, //true to add a Ext.grid.CheckBoxSelectionModel,default(true) pagingBar:true, //true to add a Ext.PagingToolBar,default(true) pagingConfig:objcet, //config pagingToolBar if pagingBar is true keepSelectedOnPaging: true, //true to FireEvent when you paging to keep the state of record selected recordIds : new Array() , // store seleced ids when keepSelectedOnPaging is true idColName :'stat_id', //the id column name ...another width : 700, height: 600, title : 'This is My Grid' , renderTo: 'my_grid' }); myGrid.store.load({params:{start:0,limit:myGrid.pagingConfig.pageSize}}); //myUxGrid.render(); myGrid.on('rowclick',function(grid,rowIndex,e){ alert(grid.getStore().getAt(rowIndex).data['stat_id']); } ); } ); */ Ext.namespace('Ext.ux.grid'); Ext.ux.grid.CollectGrid = Ext.extend(Ext.grid.GridPanel,{ /* * true to keep the records selected when you paging * @default(false) * @type: boolean */ keepSelectedOnPaging: false, /* * the array to store the record id * @type: array */ recordIds:new Array(), /* * set your id Column Name * @default : this.CM_JR_Record[0].dataIndex */ idColName:'', /* * set this.store.load url; * @type: string */ url: '', /* * show the rowNumber or not * @type: boolean * @default: true */ rowNumber : true, /* * set the grid sm,if checkBoxSelection=true,sm=CheckBoxSelectionModel * else sm=RowSelectionModel,default to true; * @type: boolean */ checkBox: true, /* * set the grid cm array; * set the JsonReader record; * * format: [{name:'',header:'',visiable:'',...another cm options},{}], * @name=dataIndex * @visiable: set this record to the cm(grid header) default(true) * @type: array (records) */ CM_JR_Record: null, /* * true to add a bottom paging bar * @defalut: true * @type: boolean */ pagingBar: true, /* * config paging bar if pagingBar set true * @type: object * @default: {pageSize: 20,store: this.store,displayInfo: true, * displayMsg: '当前记录数: {0} - {1} 总记录数: {2}', * emptyMsg: '<b>0</b> 条记录'} */ pagingConfig:{ pageSize: 20, //store: this.store, displayInfo: true, displayMsg: '当前记录数: {0} - {1} 总记录数: {2}', emptyMsg: '<b>0</b> 条记录' }, viewConfig:{ forceFit: true }, //private initComponent: function(){ if(this.CM_JR_Record){ this.init_SM_CM_DS(); } if(this.pagingBar){ this.init_PagingBar(); } if(this.keepSelectedOnPaging){ this.init_OnPaging(); } Ext.ux.grid.CollectGrid.superclass.initComponent.call(this); }, /* * init the grid use the config options * @return: void * @params: none */ init_SM_CM_DS: function(){ var gCm = new Array(); var gRecord = new Array(); if(this.rowNumber){ gCm[gCm.length]=new Ext.grid.RowNumberer(); } if(this.checkBox){ var sm = new Ext.grid.CheckboxSelectionModel(); gCm[gCm.length] = sm; this.selModel = sm; } for(var i=0;i<this.CM_JR_Record.length;i++) { var g = this.CM_JR_Record[i]; if(g.visiable || g.visiable=='undefined' || g.visiable==null){ gCm[gCm.length] = g; } gRecord[gRecord.length]={ name: g.dataIndex, type: g.type || 'string' } } //create grid columnModel this.cm = new Ext.grid.ColumnModel(gCm); this.cm.defaultSortable = true; //create a jsonStore this.store = new Ext.data.Store({ proxy: new Ext.data.HttpProxy({ url: this.url, method: 'post' }), reader:new Ext.data.JsonReader({ totalProperty: 'totalProperty', root: 'root' }, Ext.data.Record.create(gRecord) ) }); this.pagingConfig.store = this.store; if(this.pagingBar){ this.store.load({params:{start:0,limit:this.pagingConfig.pageSize}}); }else{ this.store.load(); } }, /* * 创建并初始化paging bar */ init_PagingBar: function(){ var bbar = new Ext.PagingToolbar(this.pagingConfig); this.bbar = bbar; }, init_OnPaging: function(){ this.idColName = this.CM_JR_Record[0].dataIndex ;//默认第一列为ID列 this.selModel.on('rowdeselect',function(selMdl,rowIndex,rec ){ for(var i=0;i<this.recordIds.length;i++) { if(rec.data[this.idColName] == this.recordIds[i]){ this.recordIds.splice(i,1); return; } } },this); this.selModel.on('rowselect',function(selMdl,rowIndex,rec){ if(this.hasElement(this.recordIds)){ for(var i=0;i<this.recordIds.length;i++){ if(rec.data[this.idColName] == this.recordIds[i]){ return; } } } this.recordIds.unshift(rec.data[this.idColName]); },this); this.store.on('load',function(st,recs){ if(this.hasElement(this.recordIds)){ st.each(function(rec){ Ext.each(this.recordIds,function(item,index,allItems){ if(rec.data[this.idColName] == item){ this.selModel.selectRecords([rec],true); return false; } },this); },this); } },this); }, hasElement : function(recIds){ if(recIds.length > 0) return true; else return false; } } )
- cgrid.rar (2.3 KB)
- 描述: 源代码js文件
- 下载次数: 242
发表评论
-
EXT CHANGELOG
2010-04-02 10:29 10503.2http://www.extjs.com/produc ... -
给Ext.Toolbar加上remove方法以移除子组件
2010-02-08 10:02 2696在用Ext.Toolbar的时候,发现竟然没有remove方法 ... -
ext panel屏蔽右键菜单
2010-01-11 14:46 2071panel.on('render',function(){ ... -
extjs htmleditor readOnly无效解决方法
2010-01-07 13:03 2548Ext 里的Ext.form.HtmlEditor里readO ... -
ext TabPanel相关
2009-04-24 12:11 2127在使用Ext.TabPanel时,经常会用到tabchang ... -
extjs GridPanel 相关
2009-04-16 16:41 2037var hmenu = this.grid.getView() ... -
extjs store 相关
2009-04-16 16:39 1236Method filterBy(fn,scope)过虑记录时 ... -
遍历ext form表单的递归方法
2009-04-10 10:54 2163function eachItem(item,inde ... -
javascript 闭包
2009-03-26 20:40 907elf8848 写道 function outer ... -
extjs - 树
2009-03-12 17:55 1848<1>重新load单一树节点(node) t ... -
查看ext的api文档
2008-12-29 22:36 2364找到这个localXHR.js(附件里有这个文件)复制到doc ... -
设置EXT提交数据的编码
2008-10-27 10:35 1362对于提交中出现的乱码,在Ext中可以修改Request Hea ... -
扩展combobox的下拉Grid
2008-09-17 12:45 3892/** * 下拉ComboBoxGrid * ... -
Ext Js 给window或panel加上热键
2008-08-21 14:25 2476如题,代码如下: var OverTimeForm = n ... -
ext 图片预览事件触发以及IE7下预览图片
2008-08-21 14:11 3060首先在FormPanel里添加图片预览区以及图片选择组件 ... -
下拉树ComboBoxTree
2008-08-21 13:44 8193在网上搜了两棵下拉树,均有一些小问题,用不了,于是自己参考它们 ... -
Ext.Panel API翻译
2008-07-22 11:17 2958Ext.Panel API翻译 引用网 ... -
ExtJs 的一些技巧与问题
2008-07-15 13:36 3855[color=white] [list=1] 修改 ... -
ExtJs 委托与回调(createDelegate && createCallback)
2008-07-15 12:44 2071author=Ext Community(译者:[http:/ ... -
ExtJs 上传控件change事件触发解决方法
2008-06-06 14:18 9465在 Ext 中,上传控件的ch ...
相关推荐
对于GridPanel中拖动选中行排序的实现,网上有不少ExtJs实现的例子,但是没有找到使用Ext.net实现的,正好最近有个需求要使用,干脆来写一个。 DEMO功能说明: 1、拖动GridPanel选中行到新位置排序。 2、在拖动结束...
在使用表格的分页功能时,我们把该控件的start与limits参数与Hibernate的分页功能影射,从页实现了动态的分页效果;而TreePanel的更新也是一个比较常见的问题,当我们点击测试按钮时,TreePanel会请求远程服务器的...
扩展的GridPanel,让其分页后保持选择状态
Ext.grid.GridPanel 是一个功能强大且广泛使用的Grid控件,但是它存在一个很大的缺陷:单元格的内容不能选中,没法选中就没法复制,这给用户带来了很多不便。这个问题的根源在于ExtJs输出的代码中,每个单元格的div...
在EXTJS框架中,Gridpanel是用于展示数据的常用组件,它提供了丰富的功能,如排序、分页、筛选等。当我们需要对数据进行更复杂的展示,例如按类别或层级分类时,多表头(Multi-Level Headers)就显得尤为重要。标题...
Ext GridPanel 是该框架中的一个重要组件,常用于展示表格数据。本文将详细介绍如何在 Ext GridPanel 中实现加链接操作,包括基本原理、代码实现及注意事项。 #### 一、Ext GridPanel 基础 在了解如何添加链接之前...
ExtJS是一个强大的JavaScript框架,它提供了丰富的组件和功能,用于构建复杂的Web应用程序。RowExpander插件是ExtJS中一个非常有用的特性,允许我们在GridPanel的每一行中添加一个可展开的区域,展示更多的详细信息...
分页功能可以通过配置`pagingToolbar`实现,它提供了一种用户友好的界面来控制数据的显示页数。以下是一个基本的配置示例: ```javascript var store = new Ext.data.Store({ proxy: new Ext.data.DWRProxy('...
每一项都是一个`Ext.grid.Column`实例。 - 示例:`columns: [{ header: '姓名', dataIndex: 'name' }, { header: '年龄', dataIndex: 'age' }]` 3. **autoExpandColumn** - 说明:此配置项指定了一个列ID,该列会...
GridPanel是EXTJS中的一个核心组件,它允许开发者以网格形式展示数据,支持多种功能,如排序、分页、筛选、编辑等。在EXTJS中,GridPanel通常与Store结合使用,Store负责管理数据,而GridPanel则负责显示这些数据。 ...
因此,掌握如何在ExtJs Grid中实现多选功能以及如何获取已选中的所有值是非常重要的。 #### 二、实现多选功能 在ExtJs中,实现Grid的多选功能主要通过`CheckboxSelectionModel`来完成。下面将详细介绍如何设置并...
在这个扩展中,TreeLoaderStore可能是结合了TreeLoader和Store概念的一个自定义类,它不仅管理树的数据,还提供了分页的功能。可能包含以下关键部分: 1. 数据接口:定义如何与服务器通信,获取分页数据。 2. 分页...
在ExtJs中,GridPanel是用于展示数据的常用组件,它可以提供丰富的功能,如排序、分页、筛选等。在实际应用中,我们经常需要监听用户的交互行为,比如双击行进行进一步的操作。本篇文章将深入讲解如何在ExtJs ...
导出过程包括:创建一个CSV字符串,或者构建一个Excel工作簿模型,然后提供下载链接供用户保存。 表格排序功能是另一个常见的需求。Extremecomponents的GridPanel支持列头点击进行排序,这得益于ColumnModel的配置...
ExtJS 是一个强大的JavaScript库,专门用于构建富客户端应用程序,特别是那些基于Web的桌面级应用。GridPanel 是 ExtJS 中的核心组件之一,它提供了一种高效、可定制的方式来展示大量结构化数据。在这个主题中,我们...
总之,ExtJS是一个功能强大的JavaScript框架,特别适合于构建复杂的、具有桌面应用级别的Web应用。GridPanel作为其代表性组件,能够灵活地展示和处理数据,是数据密集型应用的理想选择。通过深入理解和掌握ExtJS,...
Ext.NET 是一个基于.NET Framework的JavaScript库,它提供了一种高效的方式来构建富互联网应用程序(RIA)。GridPanel 是 ExtJS(Ext.NET 的基础)中的一个重要组件,用于展示数据表格。在这个场景中,我们将深入...