extJS checkboxselectionmodel 默认选中

本文介绍了一个ExtJS应用中复选框加载完成后不显示选中状态的问题及解决方案。通过对ExtJS复选框选择模型的调整,并使用延迟加载机制确保了数据加载完毕后复选框能够正确显示选中状态。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

var itmsDictWfxwStore = new Ext.data.Store({
proxy: new Ext.data.HttpProxy({
url:bocoitms_contextPath + "/dict/getAllUsedWfxw.action"
}),
reader: new Ext.data.JsonReader({
root: 'data',
id:'wfxw',
fields:["wfxw", "wfxwMs", "wfxwlb", "wfxwlbMs"]
}),
remoteSort: false
});

//加载完成所有数据后默认选中违法行为
itmsDictWfxwStore.on('load',function(){
var tempArray = _jtwfxwIds.split(",");
var _arraySelected = new Array();
for(var i=0; i < tempArray.length; i++){
itmsDictWfxwStore.each(function(record){
if(record.data.wfxw == tempArray[i]){
_arraySelected.push(record);
}
});

}
itmsDictWfxwSM.selectRecords(_arraySelected,true);
},this,{delay:1});//原来采用直接注册到监听里的方式,发现在数据加载完后,虽然数据已处于选中状态,但是复选框不显示√号,采用延迟(哪怕是1毫秒)后即显示,可能是extJS的bug

var itmsDictWfxwSM = new Ext.grid.CheckboxSelectionModel({
listeners: {
rowselect: function(sm, row, _record) {
var _index = selectedWfxwStore2.getCount();
selectedWfxwStore.insert(_index ,_record);
},
rowdeselect : function(sm, row, _record) {
selectedWfxwStore.remove(_record);
}
}
});

参考:http://fireinjava.iteye.com/blog/483922和http://www.iteye.com/problems/20024
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值