ExtJS只编辑网格单元格它是新的

ExtJS edit grid cell only it is new

本文关键字:单元格 编辑 网格 ExtJS      更新时间:2023-09-26

我有一个网格:

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

使用cellEdition:

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

现在,有一些按钮可以将行"添加到网格中,因此记录可能是新的或旧的。

  • 在将新行添加到存储/面板的情况下,我需要列bc是可编辑的
  • 如果用户试图编辑一个现有行,该行在创建面板时只是从数据库加载的,那么我只需要列c即可编辑

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

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

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