[英]Javascript for loop weird behavior
我得到以下輸出結果很奇怪:
Wait..
Request 2 Complete.
Request 2 Complete.
在簡單的for循環中:
for (var i = 0, j = urls.length; i < j; i += 1) {
$.ajax({
url: urls[i],
dataType: 'jsonp',
complete: function() {
log.append('Request ' + i + ' Complete.' + "\n");
if (i == (j - 1)) {
log.append('Done.');
}
}
});
}
為什么i
總是等於2
?
這是因為在ajax請求中對i
兩次調用都引用了for
-loop的相同i
。 在時間點上,當請求完成時(因此可以訪問i
),循環已終止,並且i
具有最終值,此處為2
。
我認為您正在尋找這樣的東西:
for (var i = 0, j = urls.length; i < j; i += 1) {
!function( i ){
$.ajax({
url: urls[i],
dataType: 'jsonp',
complete: function() {
log.append('Request ' + i + ' Complete.' + "\n");
if (i == (j - 1)) {
log.append('Done.');
}
}
});
}( i );
}
通過將i
的值傳遞給立即執行的函數,可以創建i
的各個值的副本以在ajax請求內使用。
嘗試使用
async = false;
in ajax request
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.