最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
详解闭包解决jQuery中AJAX的外部变量问题
时间:2017-04-29 编辑:简简单单 来源:一聚教程网
详解闭包解决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))); } } |
-
下一个: javascript 网页进度条简单实例
相关文章
- HTML简单购物数量小程序代码展示 10-31
- html canvas实现弹幕功能 10-31
- HTML中空格表示的意义 10-31
- html area标签解读 10-31
- html使用表单标签实现注册页面代码展示 10-31
- 使用HTML截图并保存为本地图片的代码展示 10-31