RowEditing 插件:禁用编辑和操作列删除图标

RowEditing plugin: disable editing and actioncolumn delete icon

我的应用程序有一个带网格的小型后台办公室,允许管理员编辑表单上的组合框列表。

可以使用行编辑插件编辑网格记录,也可以通过单击操作列图标删除网格记录。

但是,组合框有一个无法编辑的项目,因为在组合框上显示时会触发显示另一个表单字段的事件。

如何禁用编辑该项目的能力(更新和删除图标)?

Fiddle: https://fiddle.sencha.com/#fiddle/us6

如果不应编辑该行,则使用 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 是工作示例。