微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Ajax请求中的async属性

async属性

  • 类型:Boolean
  • 认值: true。认设置下,所有请求均为异步请求。如果需要发送同步请求,请将此选项设置为 false。

注意,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。

使用案例

$(document).on("click",".add",function(){
    var before_num = Number($("#number").val());
    var after_num = berfore_num + 1;
    $.ajax({
        url: "/add",method: "get",dataType: "json",success: function(result) {
            $("#number").val(after_num);
            conlose.log(result);
        }
    })
});

问题

  • 当连续点击时,会出现number增加的值和你点击次数不相符。

ajax认是异步的请求。当请求"/add"还未执行完成,就可能已经执行下一次请求,导致before_num不是上一次请求后的值。

解决

  • 将async置为false,用同步请求将浏览器锁住,保证before_num是上一次请求的值。

原文地址:https://www.jb51.cc/ajax/161178.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐