|
閉包意味著內層的函數可以引用存在于包圍它的函數內的變量,即使外層函數的執行已經終止。
讓我們先來看一個閉包的例子。
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
代碼①是處于函數內層,不過它可以使用外層的變量num。
閉合還能解決另一個常見的Js問題,全局變量的影響。
通過自動執行匿名函數組合閉包,便可把原本屬于全局的變量隱藏起來。看下面的例子:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
在使用setTimeout時,我們經常也用上了閉包。
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
以這種方式使用setTimeout(),可以避免一些問題。
當然使用閉包 也會帶來一些問題。如下代碼所示:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
單擊li彈出的序號為 3 ,并不是正確的序號,它引用的值是最后一次的賦值。
我們可以使用下面代碼來解決:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
通過使用閉包對作用域的控制,從而符合了我們的要求。
上面的代碼可以分解為:
[Ctrl+A 全選 注:如需引入外部Js需刷新才能執行]
閉包的概念不容易掌握,我也是花了大量時間和精力才理解。
6,小結
筆記(2),(3),(4)講解了 JavaScript中的幾個重要的內容,包括引用,函數重載,作用域,上下文對象和閉包。
引用的關鍵內容: 指針,數組引用,字符串引用,區別,傳值,傳址。
函數重載的關鍵內容: 參數的數量,參數的類型,arguments,偽數組,typeof,constructor,區別-字符串和對象。
作用域的關鍵內容: 函數劃分,全局作用域,全局對象,window對象的屬性,局部作用域,顯式聲明,隱式聲明。
上下文對象的關鍵內容: this變量,call,apply,參數區別,數組。
閉包的關鍵內容: 內層函數,外層函數,變量,setTimeout,閉包問題,最后一次的賦值,閉包和作用域。
JavaScript技術:JavaScript 中級筆記 第四章 閉包,轉載需保留來源!
鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。