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

详解闭包解决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))); } }

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

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

相关推荐