4

我有一个网格:

Ext.create('Ext.grid.Panel', {
    id: 'grid',
    store: this.store,
    columns: [{
        dataIndex: 'a'
    },{
        dataIndex: 'b'
    },{
        dataIndex: 'c'
    }],
    selModel: {
        selType: 'cellmodel'
    },
    plugins: [cellEditing]
})

其中使用 cellEditting:

var cellEditing = Ext.create('Ext.grid.plugin.CellEditing', {
    clicksToEdit: 1,
    listeners: {
        beforeedit: function(obj) {
                // Something goes here?
        }   
    }
});

现在,有“添加行”到网格的按钮,因此记录可能是新的或旧的。

  • 如果将行添加到商店/面板中,我需要列b并且c可以编辑。
  • 如果用户试图编辑在创建面板时简单地从数据库加载的现有行,我只需要c可编辑列。

我怀疑我需要向beforeedit侦听器添加一些东西,但是我对 ExtJS 和 javascript 一般是新手,所以我不知道如何描述这些条件。

4

1 回答 1

5

你肯定在正确的轨道上。'beforeedit' 事件允许您通过返回 false 来阻止编辑操作。如果您查看它的文档,您会看到您收到一个对象,该对象提供有关单元格的所有所需信息:http ://docs.sencha.com/ext-js/4-1/#!/api/Ext.grid .plugin.CellEditing-event-beforeedit

var cellEditing = Ext.create('Ext.grid.plugin.CellEditing', {
    clicksToEdit: 1,
    listeners: {
        beforeedit: function(editor, event, opts) {
            if (!event.record.phantom && event.column.dataIndex == 'columnC') {
                return false;
            }
        }   
    }
});

phantom 是一个记录属性,用于了解记录是新创建的(尚未同步到服务器)还是最初与存储中的所有其他记录一起加载。

于 2013-02-25T23:36:54.317 回答