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如何使用自定义插件动态保存表头配置(隐藏或显示)的更多相关文章
- mybatis自定义插件动态修改sql语句
step1:定义Interceptor实现org.apache.ibatis.plugin.Interceptor import org.apache.commons.logging.Log; imp ...
- bootstrap table插件动态加载表头
这篇文章主要为大家详细介绍了bootstrap table插件动态加载表头,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 bootstrap的table属性已经很熟悉了,最近遇到一个问题,犹豫 ...
- CKEditor在线编辑器增加一个自定义插件
CKEditor是一个非常优秀的在线编辑器,它的前身就是FCKEditor,CKEditor据官方说是重写了内核的,但功能和性能比FCKEditor更为强大和优越.记得07年的时候第一次接触FCKEd ...
- mybaits源码分析--自定义插件(七)
一.MyBatis插件 插件是一种常见的扩展方式,大多数开源框架也都支持用户通过添加自定义插件的方式来扩展或者改变原有的功能,MyBatis中也提供的有插件,虽然叫插件,但是实际上是通过拦截器(Int ...
- 深入学习jQuery自定义插件
原文地址:jQuery自定义插件学习 1.定义插件的方法 对象级别的插件扩展,即为jQuery类的实例增加方法, 调用:$(选择器).函数名(参数); $(‘#id’).myPlugin(o ...
- Cordova - 与iOS原生代码交互2(使用Swift开发Cordova的自定义插件)
在前一篇文章中我介绍了如何通过 js 与原生代码进行交互(Cordova - 与iOS原生代码交互1(通过JS调用Swift方法)),当时是直接对Cordova生成的iOS工程项目进行编辑操作的(添加 ...
- BrnShop开源网上商城第四讲:自定义插件
重要通知:BrnShop企业版NOSQL设计(基于Redis)已经开源!源码内置于最新版的BrnShop中,感兴趣的园友可以去下载来看看.官网地址:www.brnshop.com. 好了现在进入今天的 ...
- Qt之自定义插件(for Qt Designer)
之前Blog里面有关于QWT的编译.配置.使用的文章,分别是在VS与Creator下进行的. QWT编译.配置.使用(VS2010 + Qt5.1.0). QWT编译.配置.使用(Qt Creator ...
- BrnShop:自定义插件
BrnShop开源网上商城第四讲:自定义插件 重要通知:BrnShop企业版NOSQL设计(基于Redis)已经开源!源码内置于最新版的BrnShop中,感兴趣的园友可以去下载来看看.官网地址:www ...
随机推荐
- TyvjP1863 [Poetize I]黑魔法师之门(2014-8-27)
P1863 [Poetize I]黑魔法师之门 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 经过了16个工作日的紧张忙碌,未来的人类终于收集到了足够的能源 ...
- 多线程Demo1 了解
首先演示一下主线程的阻塞 // DYFViewController.m // 623-01-阻塞多线程 // // Created by dyf on 14-6-23. // Copy ...
- 用BeautifulSoup简单爬取BOSS直聘网岗位
用BeautifulSoup简单爬取BOSS直聘网岗位 爬取python招聘 import requests from bs4 import BeautifulSoup def fun(path): ...
- 从MySQL高可用引出对高可用架构设计的一些思考
高可用HA(High Availability)是分布式系统架构设计中必须考虑的因素之一,它通常是指,通过设计减少系统不能提供服务的时间. 假设系统一直能够提供服务,我们说系统的可用性是100%.如果 ...
- TopJUI通过简单的代码实现复杂的批量提交功能
业务系统的批量提交是常用的操作功能,使用传统的EasyUI开发时需要写不少代码才能实现,该功能在TopJUI中是如何实现的呢?本篇我们将通过简单的代码,把批量操作的具体实现分享给大家参考. <a ...
- A - Musical Theme + 二分
#include <bits/stdc++.h> using namespace std; #define LS 2*i #define RS 2*i+1 #define UP(i,x,y ...
- Django (二) url 和 模板
1. URL URL地址说明: 使用url给视图函数传参数 在url配置中将正则部分小括号括起来.比如: url(r'^time/plus/(\d{1,2})/$', views.hours_ahea ...
- python之序列化json模块与pickle模块(待补充)
一.json是所有语言都通用的一种序列化格式 只支持 : 列表,字典字符串,数字,且字典的key必须是字符串 ''' 1. dumps , loads 在内存中做数据转换: dumps : 数据类型 ...
- 打包google浏览器插件到本地
依次打开‘更多工具’--->'扩展程序',或者在google浏览器输入chrome://extensions/网址就可以打开已安装插件页面,在顶部选中‘开发者模式’后就会出现每个插件的ID,这个 ...
- C#的弱引用
关于C#中的弱引用 一:什么是弱引用 了解弱引用之前,先了解一下什么是强引用 例如 : Object obj=new Object(); 就是一个强引用,内存分配一份空间给用以存储Object ...