RowEditing 插件:禁用编辑和操作列删除图标
RowEditing plugin: disable editing and actioncolumn delete icon
我的应用程序有一个带网格的小型后台办公室,允许管理员编辑表单上的组合框列表。
可以使用行编辑插件编辑网格记录,也可以通过单击操作列图标删除网格记录。
但是,组合框有一个无法编辑的项目,因为在组合框上显示时会触发显示另一个表单字段的事件。
如何禁用编辑该项目的能力(更新和删除图标)?
如果不应编辑该行,则使用 beforeedit 事件和 return false。对于 actioncolumn - 只需检查处理程序编辑了什么记录并做适当的事情。这里是example
您可以使用 beforeedit
侦听器通过返回 false 来防止编辑记录。
beforeedit: {
fn: function(event,editor){
switch (editor.record.data.name) {
case 'NOT EDIT':
return false;
break;
default:return true;
}
}
},
您可以在 actioncolumn
中使用 isDisabled
来禁用记录的删除图标:
isDisabled: function (view, rowIndex, colIndex, item, record) {
if (record.data.name =='NOT EDIT')
return true;
else
return false;
},
完整代码:
var nameModel = Ext.create('Ext.data.Model', {fields: ['name']});
var store = Ext.create('Ext.data.Store', {
storeId: 'numberStore',
model:nameModel,
data: {
'items': [{
'name': 'one'
}, {
'name': 'two'
}, {
'name': 'three'
}, {
'name': 'NOT EDIT'
}]
},
proxy: {
type: 'memory',
reader: {
type: 'json',
rootProperty: 'items'
}
}
});
var grid = Ext.create('Ext.grid.Panel', {
width: 350,
height: 220,
border: true,
title: 'Grid - item dblclick',
itemId:'gridItemId',
store: Ext.data.StoreManager.lookup('numberStore'),
selType: 'rowmodel',
plugins: {
ptype: 'rowediting',
clicksToEdit: 2,
pluginId: 'roweditingId',
saveBtnText : "Save",
listeners: {
edit: function(editor, context, eOpts){
var grid = Ext.ComponentQuery.query('#gridItemId')[0];
var store = grid.getStore();
var txtColIdx = 1;
var textfieldRef = context.grid.columns[txtColIdx].getEditor(context.record);
var tetxfieldValue = textfieldRef.getValue();
context.record.set('name', tetxfieldValue);
store.sync({
success : function(record, operation) {
console.log('OK');
},
failure : function(record, operation) {
this.store.rejectChanges();
}
});
},
beforeedit: {
fn: function(event,editor){
switch (editor.value) {
case 'NOT EDIT':
return false;
break;
default:
return true;
}
}
},
canceledit : function ( editor, context, eOpts ){
}
}
},
columns: [{
text: 'name',
name:'name',
dataIndex: 'name',
sortable : false,
hideable: false,
flex: 1,
editor: {
xtype: 'textfield',
allowBlank: false
}
}, {
xtype: 'actioncolumn',
minWidth: 40,
flex: 0.20,
align: 'center',
items: [{
icon: 'delete.png',
tooltip: 'Delete record',
isDisabled: function (view, rowIndex, colIndex, item, record) {
if (record.data.name =='NOT EDIT')
return true;
else
return false;
},
handler: function(grid, rowIndex, colIndex, item, e, rec) {
grid.getStore().removeAt(rowIndex);
}, }]
}],
renderTo: Ext.getBody()
});
Here 是工作示例。
我的应用程序有一个带网格的小型后台办公室,允许管理员编辑表单上的组合框列表。
可以使用行编辑插件编辑网格记录,也可以通过单击操作列图标删除网格记录。
但是,组合框有一个无法编辑的项目,因为在组合框上显示时会触发显示另一个表单字段的事件。
如何禁用编辑该项目的能力(更新和删除图标)?
如果不应编辑该行,则使用 beforeedit 事件和 return false。对于 actioncolumn - 只需检查处理程序编辑了什么记录并做适当的事情。这里是example
您可以使用 beforeedit
侦听器通过返回 false 来防止编辑记录。
beforeedit: {
fn: function(event,editor){
switch (editor.record.data.name) {
case 'NOT EDIT':
return false;
break;
default:return true;
}
}
},
您可以在 actioncolumn
中使用 isDisabled
来禁用记录的删除图标:
isDisabled: function (view, rowIndex, colIndex, item, record) {
if (record.data.name =='NOT EDIT')
return true;
else
return false;
},
完整代码:
var nameModel = Ext.create('Ext.data.Model', {fields: ['name']});
var store = Ext.create('Ext.data.Store', {
storeId: 'numberStore',
model:nameModel,
data: {
'items': [{
'name': 'one'
}, {
'name': 'two'
}, {
'name': 'three'
}, {
'name': 'NOT EDIT'
}]
},
proxy: {
type: 'memory',
reader: {
type: 'json',
rootProperty: 'items'
}
}
});
var grid = Ext.create('Ext.grid.Panel', {
width: 350,
height: 220,
border: true,
title: 'Grid - item dblclick',
itemId:'gridItemId',
store: Ext.data.StoreManager.lookup('numberStore'),
selType: 'rowmodel',
plugins: {
ptype: 'rowediting',
clicksToEdit: 2,
pluginId: 'roweditingId',
saveBtnText : "Save",
listeners: {
edit: function(editor, context, eOpts){
var grid = Ext.ComponentQuery.query('#gridItemId')[0];
var store = grid.getStore();
var txtColIdx = 1;
var textfieldRef = context.grid.columns[txtColIdx].getEditor(context.record);
var tetxfieldValue = textfieldRef.getValue();
context.record.set('name', tetxfieldValue);
store.sync({
success : function(record, operation) {
console.log('OK');
},
failure : function(record, operation) {
this.store.rejectChanges();
}
});
},
beforeedit: {
fn: function(event,editor){
switch (editor.value) {
case 'NOT EDIT':
return false;
break;
default:
return true;
}
}
},
canceledit : function ( editor, context, eOpts ){
}
}
},
columns: [{
text: 'name',
name:'name',
dataIndex: 'name',
sortable : false,
hideable: false,
flex: 1,
editor: {
xtype: 'textfield',
allowBlank: false
}
}, {
xtype: 'actioncolumn',
minWidth: 40,
flex: 0.20,
align: 'center',
items: [{
icon: 'delete.png',
tooltip: 'Delete record',
isDisabled: function (view, rowIndex, colIndex, item, record) {
if (record.data.name =='NOT EDIT')
return true;
else
return false;
},
handler: function(grid, rowIndex, colIndex, item, e, rec) {
grid.getStore().removeAt(rowIndex);
}, }]
}],
renderTo: Ext.getBody()
});
Here 是工作示例。