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是上一次请求的值。

相关文章

IE6是一个非常老旧的网页浏览器,虽然现在很少人再使用它,但...
PHP中的count()函数是用来计算数组或容器中元素的个数。这个...
使用 AJAX(Asynchronous JavaScript and XML)技术可以在不...
Ajax(Asynchronous JavaScript and XML)是一种用于改进网页...
本文将介绍如何通过AJAX下载Excel文件流。通过AJAX,我们可以...
Ajax是一种用于客户端和服务器之间的异步通信技术。通过Ajax...