ExtJs使用自定义插件动态保存表头配置(隐藏或显示)
2018-09-25 17:11
453 查看
关于保存列表表头的配置,一般我们不需要与后台交互,直接保存在 localStorage 中就能满足常规使用需求(需要浏览器支持)。
直接上代码,插件:
Ext.define('ux.plugin.ColumnCustom', { alias: 'plugin.columnCustom', xtype: 'columnCustom', //初始化 init: function (gridPanel) { var me = this; me.owner = gridPanel; //根据已有配置项设置表头状态 me.setColumnConfig(gridPanel); gridPanel.on({ columnschanged: me.saveColumnConfig, scope: me }); }, setColumnConfig: function (gridPanel) { var me = this, xtype = gridPanel.getXType(), currentColumnConfig = me.getCurrentColumnConfig(), columnConfig = currentColumnConfig[xtype], columns = gridPanel.getColumns(); if (!columnConfig) return; columns.forEach(function (column) { var dataIndex = column.config.dataIndex; //只有常规列才有显式的dataIndex,序号列等非常规列应排除在外 if (!dataIndex) return; column.setHidden(columnConfig[dataIndex]); }); }, saveColumnConfig: function () { var me = this, gridPanel = me.owner, currentColumnConfig = me.getCurrentColumnConfig(), columns = gridPanel.getColumns(), xtype = gridPanel.getXType(), config = {}; columns.forEach(function (column) { var dataIndex = column.config.dataIndex; //只有常规列才有显式的dataIndex,序号列等非常规列应排除在外 if (!dataIndex) return; config[dataIndex] = column.isHidden(); }); //使用xtype作为索引是相对可靠的做法 currentColumnConfig[xtype] = config; //localStorage的值类型限定为string类型 localStorage.setItem('columnConfig', Ext.encode(currentColumnConfig)); }, getCurrentColumnConfig: function () { var allColumnConfigString = localStorage.getItem('columnConfig'), allColumnConfig = Ext.decode(allColumnConfigString, true); return allColumnConfig || {}; } });
如何使用:由于这是一个比较常规的需求,因此这里默认给所有的gridPanel配置此插件,并支持手动配置参数禁用之,考虑复写gridPanel类。
代码如下:
Ext.define('override.grid.Panel', { override: 'Ext.grid.Panel', requires: ['ux.plugin.ColumnCustom'], columnCustomDisable: false, initComponent: function () { var me = this; me.callParent(); //默认全部加上自动保存表头插件,此处追加一个可配属性来禁用此插件 if (!me.columnCustomDisable) { me.addPlugin('columnCustom'); } } });
总结
以上所述是小编给大家介绍的ExtJs使用自定义插件动态保存表头配置(隐藏或显示),希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!
您可能感兴趣的文章:
相关文章推荐
- Extjs 自定义树结构实现以及点击不同节点动态生成不同表头显示效果
- ASP.NET GridView动态显示隐藏列,并保存客户的配置(用户控件Cookie版)
- Emacs自定义配置文件 - google-c-style.el等编程插件使用方法
- ExtJs 4.x 学习小记:Ext.TabPanel动态隐藏及显示
- Repeater控件的使用 (原样导出和动态显示/隐藏Repeater中的列)
- android应用面试宝典(下);用自定义组件控制循环组件使用bug还添加标志显示答案标志位;通过包名读取配置文件AndroidManifest.xml
- js控制图片上传预览,使用三方插件+名称显示和控件非display:none隐藏
- dskinlite(uieasy mfc界面库)使用记录3:绘制动态元素(按钮控件通过隐藏方式修改图片显示)
- 如何在Web页中动态配置和保存自定义数据
- 扩展EasyUI datagrid 增加表头右键菜单功能,可动态对列进行显示和隐藏
- js简单显示和隐藏div,触发超链接,动态更改button值,setInterval()简单使用,jquery easyui弹出框简单使用
- 自定义 动态显示图片留白比例插件
- Android 在ViewPager中使用的可以画线,放大,保存,点击删除线条的自定义图片显示控件
- 扩展bootstrap-table插件,使其在设置显示/隐藏列时,将设置保存至cookie或者服务器端
- jqgrid + bootstrap-select 自定义表头列显示隐藏
- Control Study->AdRotator广告控件显示自定义配置文件中广告以及与DataGrid控件结合使用显示图片(示例代码下载)
- 写 smarty 插件 前奏 动态 注册 自定义 php 函数 模板中使用
- Repeater控件的使用 (原样导出和动态显示/隐藏Repeater中的列)
- 在Eclipse中使用spket插件配置ExtJS环境
- Control Study->AdRotator广告控件显示自定义配置文件中广告以及与DataGrid控件结合使用显示图片(示例代码下载)