JavaScript

超轻量级php框架startmvc

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

更新时间:2020-04-25 08:10:01 作者:startmvc
详解闭包解决jQuery中AJAX的外部变量问题在AJAX中,我们经常都要使用外部变量,经常会多次

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

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


 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+" #distributorId").val(strArr[0]);
 $("#carList0"+i+" #font16").html(strArr[strArr.length-1]);
 }
 });

 }
 }

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

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


 function getCarInfo(){
 for(var i=0;i<4;i++){
 ((function(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+" #distributorId").val(strArr[0]);
 $("#carList0"+i+" #font16").html(strArr[strArr.length-1]);
 }
 });
 }(i)));
 }
 }

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

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