從JavaScript 閉包存取循環中的外部變數
存取循環內宣告的變數時會出現問題,特別是稍後再引用此類變數時在非同步回調中。為了舉例說明,請考慮以下程式碼片段:
在這種情況下,item 變數將隨著每次循環迭代而變更。當稍後引用 item 時,它將保存數組中最後一項的值。
解決方案:使用閉包
解決此問題的方法包括使用閉包,它會建立傳回其他函數的函數。透過使用閉包,item 變數的作用域可以不同,如下所示:
替代方案:jQuery 的$.each() Helper
如果jQuery 可用, $.each() 幫助器可以用作簡單for/each 循環的簡寫。由於作用域在其函數呼叫中的工作方式,它減少了對閉包的需求:
以上是如何從 JavaScript 閉包存取循環中的外部變數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!