加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 03:36:47 所属栏目:百科 来源:网络整理
导读:首先看代码: 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 (op

首先看代码:
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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读