2

我按照编写器中的说明创建具有 CRUD 能力的网格,但问题是当我编辑现有行并 save() 它将脏行识别为创建时,我认为问题可能出在我的 idProperty 和link中,但不能弄清楚如何。

这是我的代码

立柱模型

var xsmWin = new Ext.grid.CheckboxSelectionModel({checkOnly:true});
var xcmWin = new Ext.grid.ColumnModel([
    xsmWin,
                new Ext.grid.RowNumberer(),
                {header: 'id', dataIndex: 'finCol0', align: 'left', hidden: true, hideable: false, sortable: false, width: 70},
                {header: 'column name', dataIndex: 'finCol2', align: 'left', hidden: false, hideable: false, sortable: true, width: 100, editor: new samart.form.xTextField({allowBlank: false})},
                {header: 'input type', dataIndex: 'finCol3', align: 'left', hidden: false, hideable: false, sortable: true, width: 100},
                {header: 'approve', dataIndex: 'approveFlag', align: 'center', hidden: false, hideable: false, sortable: true, width: 50},
               ]); 

代理

var proxyWin = new Ext.data.HttpProxy({
            api : {
                read : {
                    url     : SERVLET_URL + '&action=loadInnerDataGrid',
                    method: 'POST' 
                },
                create : {
                    url     : SERVLET_URL + '&action=createInnerData',
                    method: 'POST' 
                },
                update : {
                    url     : SERVLET_URL + '&action=updateInnerData',
                    method: 'POST' 
                },
                destroy : {
                    url     : SERVLET_URL + '&action=destroyInnerData',
                    method: 'POST' 
                }
            }
        });

读者和作家

var writerWin = new Ext.data.JsonWriter({
            encode: true,
            writeAllFields: false
        });
        var readerWin = new Ext.data.JsonReader(
            { 
                idProperty: 'finCol0',
              root: 'data'

            },[
                {name: 'finCol0',mapping:'fundHeadSeq'},
                //{name: 'finCol1',mapping:'fundType'},
                {name: 'finCol2',mapping:'headLabel'},
                {name: 'finCol3',mapping:'objectName'},
                {name: 'approveFlag',convert: function(v, record){
                    if (record.approveFlag == 'Y') {
                        return 'Yes';
                    } else if (record.approveFlag == 'N') {
                        return 'No';
                    }
                }},
            ]
        )

店铺

var xstoreWin = new Ext.ux.data.PagingStore({

            storeId : 'xstoreWin',
             proxy   : proxyWin,
             reader  : readerWin,
             writer : writerWin,
             autoSave : false,
             autoLoad : true

        });
4

2 回答 2

2

我有零钱

idProperty : 'finCol0' to idProperty : 'fundHeadSeq'

 {name: 'finCol0',mapping:'fundHeadSeq'}, to {name: 'fundHeadSeq',mapping:'fundHeadSeq'},

在 JSONWriter 中并更改

{header: 'id', dataIndex: 'finCol0', align: 'left', hidden: true, hideable: false, sortable: false, width: 70},
to
{header: 'id', dataIndex: 'fundHeadSeq', align: 'left', hidden: true, hideable: false, sortable: false, width: 70},

在列模型中,一切都按预期工作。

于 2011-09-24T10:07:12.630 回答
0

我有一个和你类似的问题。

我的IdProperty曾经'user_id'和作家创作从未被调用过。我改成'userId'现在可以工作了。

很奇怪。我在下Extjs 3.4

于 2012-06-22T08:00:06.867 回答