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中。
總結
以上是生活随笔為你收集整理的ajax和for循环谁难,关于“for”循环中jquery $ .ajax的问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ftp服务器上传文件提示451,解决II
- 下一篇: 服务器物理内存总是九十几,服务器物理内存