一、grid的例:
二、自定义渲染函数示例:
三、Ext.selection.CellModel(单元格选择模式)示例
四、Ext.selection.RowModel(行选择模式)示例--主要相关代码
五、Ext.selection.CheckboxModel(复选框选择模式)示例--关键代码
六、grid中的features使用
Ext.grid.feature.RowBody示例--关键代码
Ext.grid.feature.Summary示例--关键代码
Ext.grid.feature.Grouping示例--关键代码
Ext.grid.feature.GroupingSummary示例--关键代码
七、Ext.grid.plugin.CellEditing示例--关键代码
八、Ext.grid.plugin.RowEditing示例--关键代码
九、Ext.grid.plugin.DragDrop示例--关键代码
十、Ext.grid.property.Grid示例
- //配置表格列
- {header: "姓名", width: 50, dataIndex: 'name'},
- {header: "组长", width: 50, dataIndex: 'leader',
- xtype: 'booleancolumn',//Ext.grid.column.Boolean布尔列
- trueText: '是',
- falseText: '否'
- },
- {header: "生日", width: 100, dataIndex: 'birthday',
- xtype : 'datecolumn',//Ext.grid.column.Date日期列
- format : 'Y年m月d日'//日期格式化字符串
- },
- {header: "薪资", width: 50, dataIndex: 'salary',
- xtype: 'numbercolumn',//Ext.grid.column.Number数字列
- format:'0,000'//数字格式化字符串
- }
- xtype: 'actioncolumn',//Ext.grid.column.Action动作列
- items: [{
- icon: 'images/edit.gif',//指定编辑图标资源的URL
- handler: function(grid, rowIndex, colIndex) {
- //获取被操作的数据记录
- var rec = grid.getStore().getAt(rowIndex);
- alert("编辑 " + rec.get('name'));
- }
- },{
- icon: 'images/del.gif',//指定编辑图标资源的URL
- handler: function(grid, rowIndex, colIndex) {
- var rec = grid.getStore().getAt(rowIndex);
- alert("删除 " + rec.get('name'));
- }
- },{
- icon: 'images/save.gif',//指定编辑图标资源的URL
- handler: function(grid, rowIndex, colIndex) {
- var rec = grid.getStore().getAt(rowIndex);
- alert("保存 " + rec.get('name'));
- }
- }]
- {
- header: "描述", width: 100,
- xtype: 'templatecolumn',//Ext.grid.column.Template数字列
- tpl : '{name}<tpl if="leader == false">不</tpl>是组长'
- }
- Ext.create('Ext.grid.RowNumberer',{text : '行号', width : 35})
二、自定义渲染函数示例:
- //定义渲染函数,格式化性别显示
- function formatSex(value){
- return value=='man'?'男':'<font color=red>女</font>';
- }
- //定义渲染函数,格式化年龄显示
- function formatAge(value,metadata){
- if(value < 30){ //年龄小于30的设置背景颜色为#CCFFFF
- metadata.style = 'background-color:#CCFFFF;';
- }
- return value;
- }
- columns: [//配置表格列
- {header: "id", width: 30, dataIndex: 'id'},
- {header: "姓名", width: 50, dataIndex: 'name'},
- {header: "性别", width: 50, dataIndex: 'sex',renderer:formatSex},
- {header: "生日", width: 100, dataIndex: 'birthday',
- //格式化生日显示
- renderer:Ext.util.Format.dateRenderer('Y年m月d日') },
- {header: "年龄", width: 50, dataIndex: 'age',renderer:formatAge}
- ]
三、Ext.selection.CellModel(单元格选择模式)示例
- //创建表格数据
- var datas = [
- [100,'张三',24], [200,'李四',30], [300,'王五',29]
- ];
- //创建Grid表格组件
- var grid = Ext.create('Ext.grid.Panel',{
- title : '单元格选择模式示例',
- renderTo: Ext.getBody(),
- width:200,
- height:170,
- frame:true,
- selType: 'cellmodel',//设置为单元格选择模式Ext.selection.CellModel
- tbar : [{
- text : '取得所选单元格',
- handler : function(){
- var cell = grid.getSelectionModel().getCurrentPosition();
- alert(Ext.JSON.encode(cell));
- }
- }],
- store: {//配置数据源
- fields: ['id','name','age'],//定义字段
- proxy: {
- type: 'memory',//Ext.data.proxy.Memory内存代理
- data : datas,//读取内嵌数据
- reader : 'array'//Ext.data.reader.Array解析器
- },
- autoLoad: true//自动加载
- },
- columns: [//配置表格列
- {header: "id", width: 30, dataIndex: 'id', sortable: true},
- {header: "姓名", width: 80, dataIndex: 'name', sortable: true},
- {header: "年龄", width: 80, dataIndex: 'age', sortable: true}
- ]
- });
四、Ext.selection.RowModel(行选择模式)示例--主要相关代码
- simpleSelect : true,//启用简单选择功能
- multiSelect : true,//支持多选
- selType: 'rowmodel',//设置为单元格选择模式Ext.selection.RowModel
- tbar : [{
- text : '取得所选行',
- handler : function(){
- var msg = '';
- var rows = grid.getSelectionModel().getSelection();
- for(var i = 0; i < rows.length; i++){
- msg = msg + rows[i].get('name') + '\n';
- }
- alert(msg);
- }
- }]
五、Ext.selection.CheckboxModel(复选框选择模式)示例--关键代码
- //注册复选框选择模式别名为selection.checkboxmodel
- Ext.ClassManager.setAlias('Ext.selection.CheckboxModel','selection.checkboxmodel');
- multiSelect : true,//支持多选
- selModel: {
- selType : 'checkboxmodel'//复选框选择模式Ext.selection.CheckboxModel
- },
- tbar : [{
- text : '取得所选行',
- handler : function(){
- var msg = '';
- var rows = grid.getSelectionModel().getSelection();
- for(var i = 0; i < rows.length; i++){
- msg = msg + rows[i].get('name') + '\n';
- }
- alert(msg);
- }
- }]
六、grid中的features使用
Ext.grid.feature.RowBody示例--关键代码
- features: [Ext.create('Ext.grid.feature.RowBody',{
- getAdditionalData: function(data, idx, record, orig) {
- var headerCt = this.view.headerCt,
- colspan = headerCt.getColumnCount();//获取表格的列数
- return {
- rowBody: record.get('introduce'),//指定行体内容
- rowBodyCls: 'rowbodyColor',//指定行体样式
- rowBodyColspan: colspan//指定行体跨列的列数
- };
- }
- })]
Ext.grid.feature.Summary示例--关键代码
- features: [{
- ftype: 'summary'//Ext.grid.feature.Summary表格汇总特性
- }],
- columns: [//配置表格列
- {header: "姓名", flex: 1, dataIndex: 'name',
- summaryType: 'count',//求数量
- summaryRenderer: function(value){
- return '员工总数:'+value
- }
- },
- {header: "薪资", flex: 1, dataIndex: 'salary',
- summaryType: 'average',//求平均值
- summaryRenderer: function(value){
- return '平均薪资:'+value
- }
- }
- ]
- features: [Ext.create('Ext.grid.feature.Grouping', {
- groupByText : '用本字段分组',
- showGroupsText : '显示分组',
- groupHeaderTpl: '性别: {name} ({rows.length})', //分组标题模版
- startCollapsed: true //设置初始分组是否收起
- })],
- columns: [//配置表格列
- {header: "姓名", flex: 1, dataIndex: 'name'},
- {header: "性别", flex: 1, dataIndex: 'sex'},
- {header: "年龄", flex: 1, dataIndex: 'age'}
- ]
- features: [Ext.create('Ext.grid.feature.GroupingSummary', {
- groupByText : '用本字段分组',
- showGroupsText : '显示分组',
- groupHeaderTpl: '性别: {name} ({rows.length})', //分组标题模版
- startCollapsed: true //设置初始分组是否收起
- })],
- columns: [//配置表格列
- {header: "姓名", width: 100, dataIndex: 'name',
- summaryType: 'count',//求数量
- summaryRenderer: function(value){
- return '员工总数:'+value
- }
- },
- {header: "性别", width: 50, dataIndex: 'sex'},
- {header: "年龄", width: 110, dataIndex: 'age',
- summaryType: 'average',//求数量
- summaryRenderer: function(value){
- return '平均年龄:'+value
- }
- }
- ]
七、Ext.grid.plugin.CellEditing示例--关键代码
- plugins: [
- Ext.create('Ext.grid.plugin.CellEditing', {
- clicksToEdit: 1//设置鼠标单击1次进入编辑状态
- })
- ],
- selType: 'cellmodel',//设置为单元格选择模式
- columns: [//配置表格列
- Ext.create('Ext.grid.RowNumberer',{text : '行号', width : 35}),
- {header: "姓名", width: 50, dataIndex: 'name',
- editor: {//文本字段
- xtype:'textfield',
- allowBlank:false
- }
- },
- {header: "生日", width: 100, dataIndex: 'birthday',
- xtype : 'datecolumn',//Ext.grid.column.Date日期列
- format : 'Y年m月d日',//日期格式化字符串
- editor: {//日期字段
- xtype:'datefield',
- allowBlank:false
- }
- },
- {header: "薪资", width: 50, dataIndex: 'salary',
- xtype: 'numbercolumn',//Ext.grid.column.Number数字列
- format:'0,000',//数字格式化字符串
- editor: {//数字字段
- xtype:'numberfield',
- allowBlank:false
- }
- }
- ]
八、Ext.grid.plugin.RowEditing示例--关键代码
- plugins: [
- //行编辑模式
- Ext.create('Ext.grid.plugin.RowEditing', {
- clicksToEdit: 1
- })
- ],
- selType: 'rowmodel',//设置为单元格选择模式
- columns: [//配置表格列
- Ext.create('Ext.grid.RowNumberer',{text : '行号', width : 35}),
- {header: "姓名", width: 50, dataIndex: 'name',
- editor: {//文本字段
- xtype:'textfield',
- allowBlank:false
- }
- },
- {header: "生日", width: 100, dataIndex: 'birthday',
- xtype : 'datecolumn',//Ext.grid.column.Date日期列
- format : 'Y年m月d日',//日期格式化字符串
- editor: {//日期字段
- xtype:'datefield',
- allowBlank:false
- }
- },
- {header: "薪资", width: 50, dataIndex: 'salary',
- xtype: 'numbercolumn',//Ext.grid.column.Number数字列
- format:'0,000',//数字格式化字符串
- editor: {//数字字段
- xtype:'numberfield',
- allowBlank:false
- }
- }
- ]
九、Ext.grid.plugin.DragDrop示例--关键代码
- viewConfig: {
- plugins: [
- //行编辑模式
- Ext.create('Ext.grid.plugin.DragDrop',{
- dragGroup: 'grid1',//拖拽组名称
- dropGroup: 'grid2'//拖放组名称
- })
- ]
- }
十、Ext.grid.property.Grid示例
- //创建属性表格
- var grid = new Ext.grid.property.Grid({
- title: 'Ext.grid.property.Grid示例',
- width: 300,
- height: 200,
- renderTo: Ext.getBody(),
- //自定义属性编辑器
- customEditors : {
- "性别" : new Ext.form.ComboBox({
- editable : false,
- displayField:'sex',
- mode: 'local',
- triggerAction: 'all',
- store:new Ext.data.SimpleStore({
- fields: ['sex'],
- data : [['男'],['女']]
- })
- }),
- "出生日期": new Ext.form.DateField({
- format : 'Y年m月d日',
- selectOnFocus:true,
- allowBlank : false
- })
- },
- //自定义渲染函数
- customRenderers: {
- //格式化布尔值显示
- "是否已婚": function(v){
- return v?'是':'否';
- },
- //格式化日期显示
- "出生日期": Ext.util.Format.dateRenderer('Y年m月d日')
- },
- source: {
- "员工名称" : "张三",
- "出生日期" : Ext.Date.parse('10/15/2006', 'm/d/Y'),
- "性别" : '男',
- "是否已婚" : false,
- "年龄" : 29
- }
- });
相关推荐
在给定的"Extjs4 grid使用例子"中,我们可以深入理解如何在MVC架构下有效地利用ExtJS4的Grid组件。Grid组件是ExtJS中的核心部分,它提供了一个灵活的、可定制的数据展示网格,通常用于显示和操作大量数据。 1. **...
Extjs4 grid 导出为Excel 下载后放在网站(不放在网站中导出按钮不能会点击无响应,因为这里调用了swf文件)里可直接运行index.html测试 <link href='...
### ExtJs 4 Grid 与 jqGrid 对比分析 #### 一、数据展示对比 在数据展示方面,ExtJs 4 Grid 和 jqGrid 都采用了 JSON 格式的数据交互方式,但两者在实现机制上存在一定的差异。 1. **ExtJs 4 Grid**: - **耦合...
extjs4 grid 包括form js代码
### Extjs4 Grid分页与自动刷新 #### 一、Extjs4 Grid 分页功能实现 在使用Extjs4进行Web应用开发时,Grid控件是常用的数据展示组件之一。对于大数据量的情况,通常需要使用分页来提高用户体验。下面详细介绍如何...
EXTJS4 GRID 表格 分页 编辑 添加判断 颜色判断 分组 等示例
这是利用sencha cmd 生成的GridFilterDemo工程中的app和build文件夹,其余文件过大并且与主题无关,因此未包含。具体方法,请参看我的博客: 《Extjs4.2 Grid Filter Feature 表格过滤特性》
在EXTJS 4.0 MVC模式下开发时,Grid组件是数据展示的核心部分,它可以用于显示大量结构化数据。在本例中,我们探讨如何在Grid中添加单元格级别的事件处理,尤其是`cellclick`事件。`cellclick`事件允许我们在用户...
在EXTJS中,Grid控件是用于展示大量结构化数据的关键组件,具有丰富的功能和高度可定制性。本文将深入讲解EXTJS Grid如何实现数据导出到Excel文件的功能。 首先,我们要明白EXTJS Grid的数据导出到Excel的过程通常...
总的来说,"extjs4打印grid插件"是ExtJS4开发中非常实用的一个工具,它为Grid Panel提供了方便的打印功能,极大地丰富了用户体验,特别是在数据报告和数据分析场景中。通过深入理解和使用这个插件,开发者可以更好地...
Extjs动态Grid的生成 htm
在myapp4项目中,你可能会找到相关的代码示例,展示了如何在实际应用中配置和使用ExtJS Grid的过滤功能。通过阅读和理解这些代码,你可以更好地理解和应用上述理论知识。 总结来说,ExtJS Grid的过滤操作提供了...
在本文中,我们将深入探讨如何在ExtJS 4框架中实现Grid组件的修改和删除功能,同时结合Struts2和Hibernate技术,构建一个完整的CRUD(创建、读取、更新、删除)应用。ExtJS 4是一个强大的JavaScript UI库,提供了...
在标题中提到的"ExtJS4.0 分享Grid导出Excel插件"是一个扩展功能,允许用户将ExtJS Grid中的数据导出为Microsoft Excel格式的文件。这对于数据分析、报表生成以及数据共享非常有用。 这个插件是针对ExtJS 4.0版本...
ExtJS4学习笔记(九)---ExtJS4 EditGrid(可编辑的Grid) ExtJS4学习笔记(二)---HBox的使用 ExtJS4学习笔记(五)---Grid分页 ExtJS4学习笔记(八)---Grid多选 全选 ExtJS4学习笔记(六)---多表头Grid ExtJS4学习笔记(十)--...
在使用ExtJS4开发一个grid的时候,经常会遇到需要对grid的列进行动态的显示和隐藏操作,以适应不同的显示需求。ExtJS4中的gridpanel组件提供了一些内置的方法来控制列的可见性,但有时候需要一个更直观的方式来实现...
在ExtJS4中,Grid是用于展示数据的一种常见组件,它允许用户进行数据的浏览、排序、筛选等操作。本文将重点讲解如何利用Column的`renderer`函数来改变Grid单元格的背景颜色。`renderer`函数是一个非常强大的特性,它...
在ExtJs 6.5版本中,开发人员经常需要实现数据导出功能,特别是对于Grid组件,这是一项常见的需求。Grid列表通常用于展示大量结构化的数据,而导出功能可以帮助用户将这些数据保存到本地,方便进一步分析或共享。...
- 首先,我们需要创建一个继承自EXTJS的`Ext.grid.GridView`的自定义View类。这个类将覆盖默认的渲染逻辑,以便在表格底部插入合计行。 - 在`GridSummary.js`文件中,我们可以定义这个类,并重写`onRender`方法,...
在ExtJS4中,动态生成的Grid控件是一种常见的数据展示方式,它可以灵活地根据后台数据动态构建列结构。然而,对于这样的Grid,如何将其内容导出为Excel格式可能会成为一个挑战。本文将介绍一个实现这一功能的示例,...