十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章将为大家详细讲解有关ExtJs怎么使用自定义插件动态保存表头配置,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
创新互联建站是一家集网站建设,潞州企业网站建设,潞州品牌网站建设,网站定制,潞州网站建设报价,网络营销,网络优化,潞州网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。关于保存列表表头的配置,一般我们不需要与后台交互,直接保存在 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怎么使用自定义插件动态保存表头配置”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。