Extjs使用Ext.ajax时报错:too much recursion

前端之家收集整理的这篇文章主要介绍了Extjs使用Ext.ajax时报错:too much recursion前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

首先看代码
var record = viewmodel.get(‘current.record’);
Ext.Ajax.request({
url: ‘ims/ckcp/audit/approve’,
method: ‘POST’,
headers: { ‘Content-Type’: ‘application/json’ },
params :Ext.JSON.encode(record),
callback: function (options,success,response) {
if (success) {
var responseJson = Ext.JSON.decode(response.responseText);
var returnRecord = responseJson.data;
var success = responseJson.success;
if (success){
// viewmodel.set(‘data.record’,returnRecord);
Ext.Msg.alert(‘提示’,’账户审核通过成功’);
}
else{
Ext.Msg.show({
title:’失败’,
message: responseJson.msg,
buttons: Ext.Msg.YES,
icon: Ext.Msg.ERROR,
fn: function(btn) {
if (btn === ‘yes’) {
window.close();
}
}
});
}
} else {
Ext.Msg.confirm(‘失败’,
‘请求超时或网络故障,错误编号:[’ + response.status + ‘]是否要重新获取账户信息?’,function (btn) {
if (btn == ‘yes’) {
Ext.Ajax.request(options);
}
});
}
}
}); //ajax

我的record是grid中选中的一列,其实就是一个Ext.data.Model的对象,如果在ajax中直接提交此对象就会报以下错误: too much recursion

所以我们不能直接提交整个对象,而是将对象中的属性及值封装一下作为参数提交,请看代码

var record = viewmodel.get('record');
                        var param = {
                            data:[{
                                id:record.get('id'),accountNumber: record.get('accountNumber'),cardNumber: record.get('cardNumber'),subAccountNumber:record.get('subAccountNumber'),balance: record.get('balance'),hxInterest:record.get('hxInterest')
                            }]

然后在上面的ajax中的params中提交param

原文链接:https://www.f2er.com/ajax/161717.html

猜你在找的Ajax相关文章