Extjs 更换主题
这里基于 Extjs4.2(发文时官方刚发布了最新版5.0) 进行开发的,更换主题后,主题信息保存在本地 cookie 中,如果要保存在数据库中,请自行修改!
使用一个Combobox 让用户选择皮肤!
{ xtype: ‘combobox‘, itemId: ‘mycombobox1‘, padding: 0, fieldLabel: ‘皮肤更换 ‘, labelAlign: ‘right‘, labelPad: 1, labelWidth: 65, name: ‘theme‘, value: ‘ext-all.css‘, displayField: ‘name‘, forceSelection: true, queryMode: ‘local‘, store: ‘sys.Theme‘, typeAhead: true, valueField: ‘id‘, listeners: { change: { //改变选择时触发事件 fn: me.onMycomboboxChange11, scope: me }, afterrender: {//初始化数据 fn: me.onMycomboboxAfterRender11, scope: me } } }事件处理代码如下: 采用 Ext.util.CSS.swapStyleSheet() 方法设置主题。
onMycomboboxChange11: function(field, newValue, oldValue, eOpts) { if(newValue!=oldValue){ Ext.util.CSS.swapStyleSheet(‘theme‘, ‘../../extjs4.2/resources/css/‘+newValue); var cp = new Ext.state.CookieProvider(); Ext.state.Manager.setProvider(cp); cp.set("themes",newValue); } }, onMycomboboxAfterRender11: function(component, eOpts) { var cp = new Ext.state.CookieProvider(); Ext.state.Manager.setProvider(cp); //cp.set("themes",data.username); var themes = cp.get("themes"); if(themes){ component.setValue(themes); Ext.util.CSS.swapStyleSheet(‘theme‘, ‘../../extjs4.2/resources/css/‘+themes); } }附上效果图:
参考文章:
http://www.wenhaozhong.com/27.html
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。