簡體   English   中英

循環怪異行為的Javascript

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM