编程语言
首页 > 编程语言> > javascript – 如何更改ExtJS 4.2的.save()JSON输出

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

作者:互联网

我有一个问题,使用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组.
我已经测试了很多,但我真的不知道我需要改变什么才能使它工作.

谢谢

解决方法:

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

标签:json,javascript,rest,extjs,extjs4-2
来源: https://codeday.me/bug/20190708/1406340.html