1.CheckboxSelectionModel简写sm
2.实现sm是否显示
后台传入的json对象包含selected属性
- {root:[
- {id:'1',code:'1001',name:'老李',sex:'1',age:'23',selected:false},
- {id:'2',code:'1002',name:'懒蛋',sex:'1',age:'25',selected:true}
- ]}
要实现此功能必须也处理全选问题
- var sm = new Ext.grid.CheckboxSelectionModel({
- checkOnly:true,
- /*
- 解决sm全选不选中不显示的sm
- */
- selectAll : function(){
- sm.clearSelections();//清除全部的选区
- var storeLength = sm.grid.store.getCount();
- for(var i = 0; i < storeLength; i++){
- var record = sm.grid.store.getAt(i);
- //获取record中selected的值
- var selected = record.data['selected'];
- if(!selected){
- var id = record.get('id');
- //传入一个id,根据id查询缓存里的Record,返回其索引
- var si = store.indexOfId(id);
- sm.selectRow(i, true);
- }
- }
- },
- /*
- 解决sm是否显示问题
- */
- renderer:function(v, p, record){
- //获取record中selected的值
- var selected = record.data['selected'];
- if(!selected){
- //selected为false时候显示
- return '<div class="x-grid3-row-checker"> </div>';
- }else{
- //selected为true显示空
- return '';
- }
- }
- });
3.sm配置项
- var sm = new Ext.grid.CheckboxSelectionModel({
- //只允许用户通过复选框执行选中操作
- handleMouseDown : Ext.emptyFn,
- //true表示只允许选择单行
- singleSelect : true
- });