详解闭包解决jQuery中AJAX的外部变量问题
在AJAX中,我们经常都要使用外部变量,经常会多次使用,如下代码
代码如下 | 复制代码 |
functiongetCarInfo(){ for(vari=0;i<4;i++){
varcarId = $("#carList0"+i+" #carId").val(); varrequest = { city: city, carId: carId };
$.ajax({ url:"enquiry", type:'post', data:request, //async: false, success:function(data){ //alert(data); varstrArr = 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,)就可以解决这个问题,但是随之而来的是,效率减低很多。这时可以轻松使用闭包解决问题:
代码如下 | 复制代码 |
functiongetCarInfo(){ for(vari=0;i<4;i++){ ((function(i){ varcarId = $("#carList0"+i+" #carId").val(); varrequest = { city: city, carId: carId };
$.ajax({ url:"enquiry", type:'post', data:request, //async: false, success:function(data){ //alert(data); varstrArr = data.split("#"); $("#carList0"+i+" #distributorId").val(strArr[0]); $("#carList0"+i+" #font16").html(strArr[strArr.length-1]); } }); }(i))); } } |
创造与魔法 安卓版v1.0.0750
创造与魔法是一款开放世界手游,在游戏中玩家可探索这个奇妙的世
创造与魔法修改版 最新版v1.0.0750
创造与魔法无限点券版是款探索冒险游戏,该款游戏的操作还是蛮自
战争与文明官方版本 安卓版v1.7.16
战争与文明是一款由上海邮通科技有限公司开发的战争策略游戏,这
迷你世界0元领皮肤无限迷你币版 最新安卓版v1.43.0
迷你世界0元购买皮肤版是这款开放沙盒冒险建造游戏的特殊破解版
创造与魔法无限经验版 安卓版v1.0.0750
创造与魔法无限经验版是款可以改造环境,整个游戏的自由度还是蛮