Ajax请求中的async:false/true的作用

4 篇文章 0 订阅
2 篇文章 0 订阅

关于ajax 的 async:false/true的作用:
1.async默认是 true,即为异步方式,$.ajax执行后,会继续执行ajax后面的脚本,直到服务器端返回数据后,触发$.ajax里的success方法,这时候执行的是两个线程。
2.async设置为 false,则所有的请求均为同步请求,在没有返回值之前,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。
代码:

var ysxmid= ${tpcYsxm.id};
var ywslid= ${tpcYwsl.id};
$.ajax({
    url: "/yxsxk/checkWtjg.action",
    type: 'POST',
    data: {'ysxmid': ysxmid, "ywslid" : ywslid},
    async: false,
    success: function (data) {
        if (data != "" ) {
            $.messager.alert("提示信息", "请先保存添加的委托机构!", "info");
        }
    },
    error: function () {
        $.messager.alert("提示", "核验是否添加委托机构信息异常,请联系管理员处理!", "error");
    }
});
 $.messager.alert("提示信息", "ajax同步请求完成!", "info");

这个ajax请求为同步请求,在没有返回值之前,最后一行的alert是不会执行的。
如果async设置为:true,则不会等待ajax请求返回的结果,会直接执行ajax后面的语句。
不过上面设置同步请求的方法,有网友曾经反馈将async设成false后, 原意是想返回数据了再执行$.ajax后面的脚本, 没想到这个地方却导致了在火狐浏览器下出现闪屏(firefox 11.0),滚动条下拉到底部触发ajax的情况。最后只能将async:false注释掉,也就是async为ture的情况下,成功解决了火狐浏览器滚动条下拉到底部触发ajax出现闪屏的问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值