淺談JavaScript中的作用域和閉包問題_基礎知識
來源:懂視網
責編:小采
時間:2020-11-27 21:40:23
淺談JavaScript中的作用域和閉包問題_基礎知識
淺談JavaScript中的作用域和閉包問題_基礎知識:JavaScript的作用域以函數為界,不同的函數擁有相對獨立的作用域。函數內部可以聲明和訪問全局變量,也可以聲明局部變量(使用var關鍵字,函數的參數也是局部變量),但函數外部無法訪問內部的局部變量: function test() { var a = 0; //
導讀淺談JavaScript中的作用域和閉包問題_基礎知識:JavaScript的作用域以函數為界,不同的函數擁有相對獨立的作用域。函數內部可以聲明和訪問全局變量,也可以聲明局部變量(使用var關鍵字,函數的參數也是局部變量),但函數外部無法訪問內部的局部變量: function test() { var a = 0; //

JavaScript的作用域以函數為界,不同的函數擁有相對獨立的作用域。函數內部可以聲明和訪問全局變量,也可以聲明局部變量(使用var關鍵字,函數的參數也是局部變量),但函數外部無法訪問內部的局部變量:
同名的局部變量會覆蓋全局變量,但本質上它們是兩個獨立的變量,一方發生變化不會影響另一方:
一般而言,函數結束后,對函數內部變量的引用全部結束,函數內的局部變量將被回收,函數的執行環境將被清空,但是,如果以內部函數作為函數的返回結果,情況就會發生變化:
當以內部函數作為返回值時,因為函數結束后內部變量的引用并未結束,所以函數的局部變量無法回收,函數的執行環境被保留下來,因而形成了閉包效果,可以通過該引用訪問本該被回收的內部變量。
閉包還使得函數的局部變量成為“私有”變量,只能通過返回的內部函數訪問,而無法通過其他任何手段去改變。
因此,閉包可用于維持局部變量和保護變量。
不使用閉包的情況:
閉包帶來便利的同時,也會帶來一些弊端:
1、程序復雜度增加,理解更加困難
2、干擾正常的垃圾回收,復雜的閉包還可能導致內存無法回收而崩潰
3、龐大的閉包往往伴隨著性能問題
因此,閉包宜精簡小巧,而不宜龐大復雜,同時應避免大規模的使用閉包。閉包的出現,本身是語言的一個bug,但是因為它獨特的功能而保留下來。它是一個輔助手段,而不是主要功能。
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com
淺談JavaScript中的作用域和閉包問題_基礎知識
淺談JavaScript中的作用域和閉包問題_基礎知識:JavaScript的作用域以函數為界,不同的函數擁有相對獨立的作用域。函數內部可以聲明和訪問全局變量,也可以聲明局部變量(使用var關鍵字,函數的參數也是局部變量),但函數外部無法訪問內部的局部變量: function test() { var a = 0; //