ajax和for循环谁难,关于“for”循环中jquery $ .ajax的问题

我相信有一些事情正在发生。首先,$ temp_id变量被提升到函数的顶部,所以它相当于这样做:

$.ajax({

……

success:function(){

var $temp_id;

for (var i = 0; i < $children.length; i++) {

$temp_id = $children.eq(i).attr("id");

其次,即使$ temp_id在第一个循环中等于“id-1”,它也会在第二个循环中变为“id-2”,所以当你第一次调用成功回调时,它已经被改为“id-2”。

这可以解决您的问题:

更新2010-12-03:修正了一个错误

$.ajax({

……

success:function(){

for (var i = 0; i < $children.length; i++) {

var $temp_id = $children.eq(i).attr("id"); //"$children" have defined in above

$.ajax({

type: "get",

url: "Database/App_all.xml",

dataType: "html",

success: function($tid) {

return function (xml) {

var $temp_code = $(xml).find("app[id='" + $tid + "']").find("html_code").html();

$($temp_code).appendTo($("#contain")).hide().show('slow');

}

}($temp_id),

error: function () { }

});

}

}

});

我正在做的是将$ temp_id传递给返回另一个函数的函数,该函数将在成功回调中调用。现在可以安全地在成功回调中使用$ tid,因为当$ temp_id在第二个循环中发生变化时它不会受到影响。

更新:回复hh54188的评论

使用“alert”可以打破执行过程并允许意外调用ajax回调。在IE和Firefox中就是这种情况。另一方面,Chrome的行为不是这样的。要对此进行测试,您可以运行以下代码:

for (var i = 0; i < 2; i++) {

//if (i == 1) alert('stopping execution');

console.log('loop: ' + i);

$.ajax({

url: "Database/App_all.xml",

dataType: "html",

success: function () {

console.log('callback');

}

});

}

您将看到控制台中的输出为:

循环:0

循环:1

回调

回调

现在取消注释警报线。在Firefox和IE中,您将看到控制台中的输出现在是:

循环:0

回调

循环:1

回调

显示警告框时,将调用第一个回调。警报实质上改变了代码的行为。在JavaScript中进行开发时,使用“alert”可能会令人沮丧,因为它可能导致代码执行不可预测。因此,我不建议在调试时使用“alert”。相反,使用console.log()更容易预测。 console.log()适用于所有现代浏览器和IE 8+。对于较旧的IE,您需要将文本输出到DOM中。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值