Extjs store.save () не распознает обновление - PullRequest
2 голосов
/ 24 сентября 2011

Я следую инструкции в Writer , чтобы создать сетку с возможностью CRUD, но проблема в том, что когда я редактирую существующую строку и сохраняю (), она распознает эту грязную строку как create, я думаю, что проблема может заключаться в моей idProperty как в ссылка , но не может понять, как.

Вот мой код

Модель колонны

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},
               ]); 

Proxy

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

        });

Ответы [ 2 ]

2 голосов
/ 24 сентября 2011

У меня есть изменения

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},

в модели столбца и все работает, как ожидалось.

0 голосов
/ 22 июня 2012

У меня проблема похожа на вашу.

Мой IdProperty был 'user_id', а автор создания никогда не вызывался. Я изменил на 'userId' и теперь он работает.

Очень странно. Я под Extjs 3.4.

...