如何更改ExtJS 4.2的.save()JSON输出

时间:2014-01-30 09:29:46

标签: javascript json rest extjs extjs4.2

使用ExtJS可更新网格将数据保存到数据库时出现问题。 我正在使用我在Progress ABL中编写的REST API。 API正在运行,但输入JSON和输出JSON非常具体。

我可以将JSON数据读入我的网格并显示它,但是当我想保存新记录时,网格会创建一个错误的JSON输出。

我的输出必须是这样的:

   {
      "request":
        {
          "dsUsers":
            {
              "ttUsers":
                [{"ID":20,"LOGIN":"test","PASS":"","ID_ADDR":0,"ID_CUST":0}]
            }
        }
    }

但是我无法在编写器中创建请求和dsUsers组。 我已经测试了很多,但我真的不知道我需要改变什么才能让它发挥作用。

由于

1 个答案:

答案 0 :(得分:1)

Base Ext.data.writer.Json允许您仅定义根数据属性。但是,如果您需要更多这样的自定义结构,您可以非常轻松地创建自己的编写器。

您的作者应该从Ext.data.writer.Json延伸并覆盖writeRecords方法。此方法将记录数据添加到请求中。

在您的情况下,自定义编写器应如下所示:

Ext.define('myWriter', {
    extend: 'Ext.data.writer.Json',
    writeRecords: function(request, data) {
        var root = this.root;        

        if (this.expandData) {
            data = this.getExpandedData(data);
        }

        if (this.allowSingle && data.length === 1) {
            // convert to single object format
            data = data[0];
        }

        request.jsonData = request.jsonData || {};
        request.jsonData['request'] = {
            'dsUsers': {}
        };

        request.jsonData['request']['dsUsers'][root] = data;

        return request;
    }    
});

然后,您可以在模型或商店代理中使用自定义编写器:

Ext.define('User', {
    extend: 'Ext.data.Model',
    fields: ['id', 'name', 'email'],
    proxy: {
        type: 'rest',
        writer: Ext.create('myWriter', {
            root: 'ttUsers',
            mainRoot: 'dsUsers'
        }),
        url : '/users'
    }            
});

当然,您可以通过在config中定义"request""dsUsers"属性的名称来创建更具可配置性和可重用性的自定义编写器。

举例说明: https://fiddle.sencha.com/#fiddle/33l