ExtJS的Ajax提交(Ext.Ajax.request或form1.getForm().submit)超时设置timeo...

本文详细解析了ExtJS中Ajax提交的核心方法及其超时机制,包括使用Ext.Ajax.request或form.getForm().submit进行数据提交,并强调了在进行长时间数据库操作时调整超时时间的重要性,以避免操作中断。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ExtJs的Ajax提交主要是:Ext.Ajax.request或form1.getForm().submit,超时时间默认是30秒!

看ExtJs对它的解释:

timeout 超时时间,请求的超时豪秒数(默认为30秒)。

The timeout in milliseconds to be used for requests. (defaults to 30000): Number

因此,一旦在使用中,长时间的操作数据库,这时候不仅需要在页面上添加waitMsg,而且需要重新设置超时时间,防止没有提交完成就中断操作。

注意:timeout属性 需要是毫秒,比如30秒就是 30 000 毫秒了;


demo如下:

var msgTip; // 一定要定义在使用前,且定义为全局变量

Ext.Ajax.request({
timeout: 600000,
url:'sendAllTitleToBK.action',
params : '',
method : 'POST',
success : function(response,options){
var respText = Ext.util.JSON.decode(response.responseText);
var msg=respText.msg;
// 更新列表
titleStore.reload({
params : {
'start' : 0,
'limit' : pgSize
}
});
msgTip.hide();
Ext.MessageBox.alert("提示",msg);
},
failure : function(response,options){
titleStore.reload({
params : {
'start' : 0,
'limit' : pgSize
}
});
msgTip.hide();
Ext.Msg.getDialog().setWidth(500);
Ext.Msg.alert('提示','页面处理请求失败!');
}
});

//==================超时会自动跳转到failure,后台程序却依然执行================

---注意超时提示信息的打印:

failure : function(response,options){
var reqst=response.status; // 根据返回的状态码值判断是否超时
if(reqst=='-1'){ // 超时的状态码为 -1
Ext.Msg.getDialog().setWidth(500);
Ext.MessageBox.alert("提示","发送超时,可能存在网络异常,检查后请重试...");
}else{
Ext.Msg.alert('提示','发布处理失败!');
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值