extjs4 各种怪异问题
用extjs4 已经有一段时间了,过去开发的时候用过extjs2.2 因为放下了两年所有很多东西记得不是很清楚了,现在又直接使用4 突然发现这个世界变得太快连代码都变得这么快,大部分东西都完全不一样了,组建,数据交互.....,因为有采用了extjs4的新标准MVC 哎现在这个前段也搞什么三层,软件架构真是越来越复杂。在此主要整理记录一下在4中遇到一下比较奇怪的问题和解决方法,
1: MVC 初始化的问题,MVC 的核心是Controller 相当于Servlet 大量逻辑性的代码都写在里边主要需要引入 stores,
views,models 只要需要显示在页面的view都要引入到views 数组中,MVC 在加载Controller 的时候会创建stores 中所有的stores ,其他的views ,models 则不会创建对象,不知道他们这样设计的目的在于什么?
2: MVC 中 一般在View 中包含一个Store ,而在Store中会包含一个Model 的属性,view中包含store 例如store:'config.configmanage.DPCGridPanelStore', 只需要写入store的相对路径即可,但是 store 中包含model 则必须写入绝路径 model:'DELTA.model.config.configmanager.DPCModel', 不知道他们这样设计目的在于什么?
3: 属性赋值 :创建组建时候直接给组建的属性赋值 和通过Ext.apply()给组建赋值有区别,其中有一个应用就是

tab 中新增一个grid 第一次没有问题,但是如果把这个tab 关闭 在点击新增这个grid 这个grid的就会显示出现问题,搞了好长时间发现吧 分页bar 通过apply的方式赋给grid 就不会出现这个问题,如果是直接配置给gird 就会出问题实在是不能理解。
4: baseParams 使用 一般在条件分页的时候使用 在使用2.2的时候 直接通过store.load({baseParams:{a:a}}); 现在通过这个方法没法执行具体使用方法
- var new_params = { ndpcId:id};
- Ext.apply(win.query("#dpcCheckBoxTree")[0].getStore().proxy.extraParams,new_params);
- win.query("#dpcCheckBoxTree")[0].getStore().load();
var new_params = { ndpcId:id};
Ext.apply(win.query("#dpcCheckBoxTree")[0].getStore().proxy.extraParams,new_params);
win.query("#dpcCheckBoxTree")[0].getStore().load();
5: 在使用可编辑Grid 的时候 最后一步往往都是获得修改的数据集提交到后台
extjs3 的时候 通过调用store的getModifyRecords() 的方法 4以后改成getUpdatedRecords但是在调用后发现修改过的 model[] 的长度都是0 。解决办法
ext 的模型类:model有如下一个熟悉
idProperty : String
The name of the field treated as this Model's unique id (defaults to 'id').(唯一识别store中记录的字段)
默认为'id',如果没有配置这个属性,就需要在自己定义的model中提供一个名叫'id'的唯一主键。或者配置成自己的主键如:
- Ext.define('Tms.model.QualificationInfo', {
- extend : 'Ext.data.Model',
- idProperty : 'qiId',//定义自己的主键
- fields : [{
- name : 'qiId',
- type : 'int',
- useNull : true
- }, {
- name : 'qtId',
- type : 'int',
- useNull : true
- }, 'qiName', 'qiParents', 'qiNovitiate', 'qiTrainingTask']
- });
Ext.define('Tms.model.QualificationInfo', {
extend : 'Ext.data.Model',
idProperty : 'qiId',//定义自己的主键
fields : [{
name : 'qiId',
type : 'int',
useNull : true
}, {
name : 'qtId',
type : 'int',
useNull : true
}, 'qiName', 'qiParents', 'qiNovitiate', 'qiTrainingTask']
});
6: 在使用tree的时候出现点击树节点出现等待的符号无法进入的原因是 后台返回的tree 节点的id 有重复导致。
7: grid 在tab 中显示,如果同一个grid 在tab 上出现了两次就会出现 第二个grid 的数据把前一个覆盖,这个是因为grid中使用的store是单例 的你创建的多个grid 但是却创建了一个store 所以就会导致第二个在tab上新增的grid 的数据会覆盖原先打开的grid的数据 var store=Ext.widget('deviceliststore'); 然后store:store
传统的store:'Ext.data.Store' 这样的写法在创建多个grid 的时候只会穿件一个store
8:打开多个tab标签页 图标显示问题除了第一个的图标其他的无法正常显示, tbar 中如果是button 请不要指定xtype属性就可以解决
9: 在使用grid 固定列的时候 不但要设定 {xtype:'rownumberer',header:'编号',width:40,locked:true },还要设定height 的属性,不然是不能正常使用的。
10: Extjs 中的组件最好不要设置ID 而设置Name 属性, 在 例如panel 的id:p1 , 在tabpanel 中应用的时候弹出多个tab 的时候就会出现id 冲突的问题,错误现象是显示会出现异常,在tabpanel 使用的时候会经常的出现id冲突的问题
例如 按钮的id 冲突会导致图片无法显示的问题,这里说的id 冲突并不是你定义了两个id 一样的组件,而是你定义一个id但是这个组件生成了多次。
11:关于 Tree 删除的问题,如何删除除了根节点以外所有的子节点??
Ext Tree 的root 也就是根节点非常重要,TreeStore 中有一个removeAll 方法是删除树的所有节点,但是一旦删除树的所有节点就无法对树进行操作了,所以在删除的时候经常都是保留根节点进行删除
tree.getStore().getRootNode( ).removeAll();
待续。。。。。。。。
12:在可编辑的grid 中使用combobox 控件的时候选择的dispalyValue renderer以后就成了 value ,处理方法
- var alarmStore=Ext.create("Ext.data.Store", {
- fields: ["alarmStandardId", "standardName"],
- proxy:{
- type : 'ajax',
- url : 'findAlarmStandardNameList.action',
- pageParam:'pageNo',
- //model:'Delta.model.config.devicemanage.DeviceModel',
- reader : {
- type:'json' ,
- root:'alarmStandardNameList'
- }
- }
- });
- field: {
- allowBlank: true,
- xtype: 'combo',
- name:'',
- queryMode: 'remote',
- store:alarmStore,
- displayField:'standardName',
- valueField:'alarmStandardId',
- editable:false
- } ,
- renderer: function(value, metadata, record, rowIndex, columnIndex, store){
- index = alarmStore.findExact('alarmStandardId',value);
- if (index != -1){
- rs = alarmStore.getAt(index).data;
- return rs.standardName;
- }
- /*var index = store.find(buildingCombobox.valueField,value);
- var r = store.getAt(index);
- alert(r.data.buildingName);*/
- //console.log(record);
- return value;
- }
var alarmStore=Ext.create("Ext.data.Store", {
fields: ["alarmStandardId", "standardName"],
proxy:{
type : 'ajax',
url : 'findAlarmStandardNameList.action',
pageParam:'pageNo',
//model:'Delta.model.config.devicemanage.DeviceModel',
reader : {
type:'json' ,
root:'alarmStandardNameList'
}
}
});
field: {
allowBlank: true,
xtype: 'combo',
name:'',
queryMode: 'remote',
store:alarmStore,
displayField:'standardName',
valueField:'alarmStandardId',
editable:false
} ,
renderer: function(value, metadata, record, rowIndex, columnIndex, store){
index = alarmStore.findExact('alarmStandardId',value);
if (index != -1){
rs = alarmStore.getAt(index).data;
return rs.standardName;
}
/*var index = store.find(buildingCombobox.valueField,value);
var r = store.getAt(index);
alert(r.data.buildingName);*/
//console.log(record);
return value;
}
13:grid 中使用lock (固定表头) 下动态设置column 的show 和hide 方法, 在普通grid 下动态设定表头比较容易
只需要获取grid 的columns 然后设置 需要隐藏的列.columns[x].setVisible(false); 但是在使用固定表头的情况下这个方法就没法执行老是提示 no method 的就是错误,确实百撕不得骑姐,非常不正常,就在生成的js 的代码中看看什么状况吧,发现在属性plugins 中多了一些东西 其中有一个view 属性,在view属性中有找到了lockedGrid ,和normalGrid两个不同grid 呵呵知道是什么
原因了 原来固定表头其实是通过插件吧grid 分成了两个grid 真正的column 就隐藏在这两个grid中 grid.plugins[0].view.normalGrid.columns[6].setVisible(false); 呵呵搞定
14: 如何彻底隐藏列,一般开发者在使用隐藏列的时候都是hidde:true 用来隐藏列,但是这种隐藏列是不干净的,可以通过列下来在显示上,所以要想彻底隐藏列不但要设置 hidden 属性还要设置 hideable: false , 属性
15:ajax 提交返回结果中带有<per></per> ,解决方法 response.setContentType("text/html");
16、如果要允许复制Grid单元格内容,配置以下参数就可以viewConfig: {
stripeRows: true
,enableTextSelection: true
}
待续。。。。。。。。。。。。。。
原文:http://zha-zi.iteye.com/blog/1522631
extjs4 各种怪异问题的更多相关文章
- System中记录体函数命名怪异
//1019unit System; 中发现记录体函数命名怪异//乍一看,很怪异,其实是结构体里面 的变量后面直接写 函数类型了.不像传统先定义T***Event = procedure(S ...
- padding标准盒模型和怪异盒子模型
我们都知道padding是为块级元素设置内边距 但是在使用过程中,我们却会遇到一些问题.padding的标准盒模型和怪异盒模型 padding盒子模型 我们通过demo来讲这个问题,用文字干讲第一没意 ...
- ExtJs4之TreePanel
Tree介绍 树形结构,是程序开发,不可缺少的组件之一.ExtJs中的树,功能强大美观实用.功能齐全,拖拉,排序,异步加载等等. 在ExtJs4中Tree和Grid具有相同的父类,因此Grid具有的特 ...
- ExtJs4 基础必备
认识ExtJs的开发包 下载路径:http://www.sencha.com/products/extjs/download/ 解压有20多兆,别怕,真正运行的没这么大.认识下这个包的文件结构吧. b ...
- ExtJs4之Grid详细
ExtJs博客前奏 由于这段时间事情比较杂乱,博客就主要以项目中例子来说明编写. ExtJs4中的Grid非常强大,有展示,选中,搜索,排序,编辑,拖拽等基本功能,这篇博客我就这几个功能做写累述. 1 ...
- ExtJS4 源码解析(一)带项目分析
Ext这个东东太大了,能看完就已经很不错了,完整的源码分析就不敢说了,大概就涉及了类管理,事件管理,数据结构缓存架构,UI组件核心机制,MVC这几个方面,只是挑着源码看的,没有实际完整的使用. 公司的 ...
- 你所不了解的float(滥用float的怪异现象)
float设计初衷就是为了实现文字环绕效果 原本页面流布局显示如上图所示,运用了float属性后就显示为如下图所示,这就是浮动的设计初衷 float的一些特性:包裹性.破坏性. 包裹的特性其实主要有三 ...
- Extjs4 -- Ext.loader命名空间的配置
初次使用extjs4的版本,在配置学习Ext.Loader()进行js文件的动态加载机制,由于各种原因导致多次失败,纠结2天,现将解决时出现的问题及需要注意事项进行记录 开发环境myeclipse8. ...
- eclipse+spket+Extjs4.2.1开发环境搭建
一.开发工具配置 1.http://www.eclipse.org/downloads/下载Eclipse,解压. 2.http://spket.com/download.html ...
随机推荐
- CSS隐藏多余文字的几个方法
通常偏移掉字体的方式是 (1)使用text-indent:-9999px; 可是他有一个局限性 他只适用于块级元素block而我们往往有时候想偏移掉的a上的字体所以问题就来了text-indent:- ...
- Holt-Winters原理和初始值的确定
关于模型 (来自以下PPT,从第4页开始) 关于初始值: 以下文档给出了三个模型的初始值计算的思路. 大致思路如下,建立一个p阶移动平均模型,估计出参数即为初始值,具体的根据三种不同的模型,有 ...
- linux下cp覆盖原so文件时引起的段错误原因确定
原创作品,转载请注明出处http://www.cnblogs.com/leo0000/p/5694416.html 最近因为一个很有意思的段错误学习了一些新的东西. 当时现象是这样的,程序正在运行,系 ...
- 逻辑回归LR
逻辑回归算法相信很多人都很熟悉,也算是我比较熟悉的算法之一了,毕业论文当时的项目就是用的这个算法.这个算法可能不想随机森林.SVM.神经网络.GBDT等分类算法那么复杂那么高深的样子,可是绝对不能小看 ...
- Reader与InputStream两个类中的read()的区别
InputStream类的read()方法是从流里面取出一个字节,他的函数原型是 int read(); ,Reader类的read()方法则是从流里面取出一个字符(一个char),他的函数原型也是 ...
- gdbsever 使用说明
gdbsever 使用说明 在新塘N3292x平台下 编译 gdbsever ./configure --target=arm-linux --host=arm-linux arm-linux-gdb ...
- 去哪儿网输入框三种输入方式(selenium webdriver 干货)
在机票预定的页面,输入出发城市和到达城市输入框的时候, 发现直接使用sendkeys不好使, 大部分情况出现输入某城市后没有输入进去, 经过几天的研究,发现可以采取三种方式: 1. 先点击输入框,待弹 ...
- vux 表单提交数据 返回后页面跳转
ps:仅作参考
- 页面位置 top、postop、scrolltop、offsetTop、scrollHeight、offsetHeight、clientHe
1.top 此属性仅仅在对象的定位(position)属性被设置时可用.否则,此属性设置会被忽略. 代码如下: <div style=" position:absolute; widt ...
- Odoo中最小库存规则和按订单生成规则的区别
---恢复内容开始--- 最小库存规则(Minimum stock rule)用来保证你的库存产品数量总是不会低于设定的最小库存数量.用来保证产品生产和回到客户的需求.当库存产品低于这个最小库存数量时 ...