在 JavaScript 中,由於閉包問題,在 for 迴圈中執行非同步函數可能會很棘手。讓我們深入研究一個常見場景,並探討如何使用正確的方法來解決它。
考慮以下程式碼:
<code class="javascript">for(var i = 0; i < list.length; i++){ mc_cli.get(list[i], function(err, response) { do_something(i); }); }</code>
這裡呼叫了非同步函數 mc_cli.get() for 迴圈。然而,當執行回調時,由於函數的非同步特性,i 的值可能會改變。
為了解決這個問題,必須正確使用閉包。正如所提供的程式碼中所嘗試的那樣,錯誤地使用閉包會導致 i 的最後一個值重複使用。
正確的方法是使用 forEach() 而不是 for 迴圈。 forEach() 在回呼中提供清單項目及其索引,確保每次迭代都維護自己的範圍。
<code class="javascript">list.forEach(function(listItem, index){ mc_cli.get(listItem, function(err, response) { do_something(index); }); });</code>
在這個方法中,forEach() 中的每個回呼都引用其自己的唯一索引值,解決閉包問題並確保 do_something() 始終收到正確的索引值。
以上是以下是一些標題選項,全部採用問題格式: 直接、清晰: * 如何在 JavaScript 中處理 For 迴圈內的非同步呼叫? * 為什麼在Java中使用For循環進行非同步調用的詳細內容。更多資訊請關注PHP中文網其他相關文章!