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