国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

淺談JavaScript中的作用域和閉包問題

2024-05-06 16:22:55
字體:
來源:轉載
供稿:網友

這篇文章主要介紹了JavaScript中的作用域和閉包問題,是JS入門學習中的基礎知識,需要的朋友可以參考下

JavaScript的作用域以函數為界,不同的函數擁有相對獨立的作用域。函數內部可以聲明和訪問全局變量,也可以聲明局部變量(使用var關鍵字,函數的參數也是局部變量),但函數外部無法訪問內部的局部變量:

 

 
  1. function test() { 
  2. var a = 0; // 局部變量 
  3. b = 1; // 全局變量 
  4. a = ?, b = ? // a為undefined,b為1 

同名的局部變量會覆蓋全局變量,但本質上它們是兩個獨立的變量,一方發生變化不會影響另一方:

 

 
  1. a = 5; // 函數外a的值為5 
  2. function test() { 
  3. var a = 4; // 函數內a的值為4 
  4. }(); 
  5. a = ? // 函數外a的值仍為5,不受函數影響 

一般而言,函數結束后,對函數內部變量的引用全部結束,函數內的局部變量將被回收,函數的執行環境將被清空,但是,如果以內部函數作為函數的返回結果,情況就會發生變化:

 

 
  1. function test(i) { 
  2. var b = i * i; 
  3. return function() { 
  4. return b--; 
  5. }; 
  6. var a = test(8); 
  7. a(); // 返回值為64, 內部變量b為63 
  8. a(); // 返回值為63, 內部變量b為62 

當以內部函數作為返回值時,因為函數結束后內部變量的引用并未結束,所以函數的局部變量無法回收,函數的執行環境被保留下來,因而形成了閉包效果,可以通過該引用訪問本該被回收的內部變量。

閉包還使得函數的局部變量成為“私有”變量,只能通過返回的內部函數訪問,而無法通過其他任何手段去改變。

因此,閉包可用于維持局部變量和保護變量。

不使用閉包的情況:

 

 
  1. var a = []; // 假設a中包含5個元素 
  2. for (var i = 0, m = a.length; i < m; i++) { 
  3. a[i].onclick = function(e) { 
  4. return 'No. ' + i; 
  5. }; 
  6. // 點擊任何一個元素,返回值都是“No. 5”,因為i最后的值為5 
  7. 使用閉包的情況: 
  8. function test(i) { 
  9. return function(e) { 
  10. return 'No. ' + i; 
  11. }; 
  12. var a = []; // 假設a中包含5個元素 
  13. for (var i = 0, m = a.length; i < m; i++) { 
  14. a[i].onclick = test(i); 
  15. // 使用閉包維持局部變量,點擊元素返回No. 0 ~ No. 4 

閉包帶來便利的同時,也會帶來一些弊端:

1、程序復雜度增加,理解更加困難

2、干擾正常的垃圾回收,復雜的閉包還可能導致內存無法回收而崩潰

3、龐大的閉包往往伴隨著性能問題

因此,閉包宜精簡小巧,而不宜龐大復雜,同時應避免大規模的使用閉包。閉包的出現,本身是語言的一個bug,但是因為它獨特的功能而保留下來。它是一個輔助手段,而不是主要功能。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 涿鹿县| 商城县| 五常市| 民乐县| 乌鲁木齐市| 淄博市| 绥中县| 乐亭县| 长沙市| 女性| 监利县| 德令哈市| 施甸县| 丰镇市| 西乌珠穆沁旗| 逊克县| 通江县| 张家界市| 苍南县| 东城区| 承德县| 繁昌县| 喀什市| 邵阳市| 综艺| 海宁市| 临海市| 宜宾县| 丰宁| 章丘市| 宣城市| 镇宁| 翁牛特旗| 青冈县| 凤庆县| 恩施市| 襄垣县| 平邑县| 西昌市| 余庆县| 广西|