最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
详解闭包解决jQuery中AJAX的外部变量问题
时间:2022-06-27 09:06:10 编辑:袖梨 来源:一聚教程网
详解闭包解决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))); } } | |
相关文章
- jm天堂漫画-官网入口ios版下载 03-14
- ChatGpt官网入口2026最新地址-一键直达官网分享 03-14
- 七猫小说网页版入口-七猫小说网页版免费畅读 03-14
- 樱花动漫官网-樱花动漫在线观看 03-14
- 超市的漂亮大姐姐北鼻逃兵漫画最新下载安装-北鼻逃兵漫画免费阅读高清版本入口 03-14
- 粒粒的小人国测资格如何获取-粒粒的小人国测资格快速获取入口 03-14