详解闭包解决jQuery中AJAX的外部变量问题

详解闭包解决jQuery中AJAX的外部变量问题

在AJAX中,我们经常都要使用外部变量,经常会多次使用,如下代码

rush:js;"> function getCarInfo(){ for(var i=0;i<4;i++){
    var carId = $("#carList0"+i+" #carId").val();
    var request = { 
      city: city,carId: carId
    };

    $.ajax({
       url:"enquiry",type:'post',data:request,//async: false,success:function(data){
        //alert(data);
        var strArr = data.split("#");
        $("#carList0"+i+" #<a href="https://www.jb51.cc/tag/dis/" target="_blank" class="keywords">dis</a>tributorId").val(strArr[0]);
        $("#carList0"+i+" #font16").html(strArr[strArr.length-1]);
      }
    });

  }
}

我期待的是按顺序alert(1) alert(2) alert(3) alert(4),但是实际上三次都是alert(4)

这均是由于AJAX异步导致的问题,设置同步(async: false,)就可以解决这个问题,但是随之而来的是,效率减低很多。这时可以轻松使用闭包解决问题:

rush:js;"> function getCarInfo(){ for(var i=0;i<4;i++){ ((function(i){ var carId = $("#carList0"+i+" #carId").val(); var request = { city: city,success:function(data){ //alert(data); var strArr = data.split("#"); $("#carList0"+i+" #distributorId").val(strArr[0]); $("#carList0"+i+" #font16").html(strArr[strArr.length-1]); } }); }(i))); } }

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持

相关文章

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