最新下载
热门教程
- 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))); } } | |
相关文章
- 污污漫画入口风险警示-合规访问指南与安全指引 12-13
- 海棠文学城网页版官网入口-2025在线网址直达 12-13
- 土豪漫画官方APP免费下载入口-正版无广告畅读保障 12-13
- 歪歪漫画app最新版下载入口-首页畅读无广告直接进 12-13
- SkrBT磁力官网最新入口-skrbt磁力引擎极速版入口 12-13
- 微博热搜网页版极速入口-微博热搜榜官方直达链接 12-13