js中的閉包學習心得
閉包
按中文的意思就是關上一個包的意思。如果我們把函數(shù)的作用域當做是一個包的話,那這個詞很形象體現(xiàn)了它的作用 。函數(shù)的正常的執(zhí)行流程是當函數(shù)中的語句執(zhí)行完后,程序會自動銷毀這個函數(shù)的作用域,但是當一個函數(shù)中聲明了另一個函數(shù),并且這個子函數(shù)執(zhí)行時存在引用父函數(shù)的變量,就會形成閉包,形象點說就相當于把父函數(shù)的作用域給關閉了起來,不讓程序去銷毀它。
例如:
function a() {
var name = "xuxu";
function b() {
console.log(name);
}
// 此處產(chǎn)生閉包
b();
}
a();
當函數(shù)可以記住并訪問它所在的作用域鏈時,就產(chǎn)生了閉包 當然,大部分的閉包都不是這么直觀的,因為子函數(shù)的調用是可以在父函數(shù)之外的,例如:
function a() {
var name = "xuxu";
function b() {
console.log(name);
}
return b;
}
var c=a();
// 此處產(chǎn)生閉包 此處的c函數(shù)其實就是a函數(shù)
c();
通過以上代碼,我們也可以看出一個閉包的好處,就是我們再全局作用域(此處是widow)下訪問到了局部作用域(a函數(shù))的作用域的值,按正常的詞法作用域是無法這么做的,但是當我們使用閉包是就可以了。然后我們再看一點我們平時寫的比較多的:
function foo() {
var a = 2;
function baz() {
// 2
console.log( a );
}
bar( baz );
}
function bar(fn) {
// 大家快看呀,這就是閉包!
fn();
}
又或者
var fn;
function foo() {
var a = 2;
function baz() {
console.log( a );
}
// 將baz分配給全局變量
fn = baz;
}
function bar() {
// 大家快看呀,這就是閉包!
fn();
}
foo();
// 2
bar();
以上也是閉包,因此在函數(shù)內部調用子函數(shù),或者通過何種手段將內部函數(shù)傳遞到所在的詞法作用域以外,它都會持有對原始定義作用域的引用,無論在何處執(zhí)行這個函數(shù)都會使用閉包。
- 通俗易懂地解釋JS中的閉包
- JS繼承與閉包及JS實現(xiàn)繼承的三種方式
- 淺談JavaScript作用域和閉包
- JS閉包的幾種常見形式實例詳解
- JS實現(xiàn)閉包中的沙箱模式示例
- JavaScript閉包的簡單應用
- 通過示例徹底搞懂js閉包
- JavaScript閉包和回調詳解
- 淺談JS封閉函數(shù)、閉包、內置對象
- JavaScript閉包_動力節(jié)點Java學院整理
- 深入理解Javascript中的作用域鏈和閉包
- JS閉包可被利用的常見場景小結
- 利用js的閉包原理做對象封裝及調用方法
- javascript閉包功能與用法實例分析
- JavaScript中閉包的詳解
- JS閉包用法實例分析
- 圖解Javascript——作用域、作用域鏈、閉包
- 輕松理解JavaScript閉包
相關文章
根據(jù)對象的某一屬性進行排序的js代碼(如:name,age)
實例為按降序排列,若想改為升序只需把比較器中的value2-value1改為value1-value2就可以了2010-08-08
Openlayers+EasyUI Tree動態(tài)實現(xiàn)圖層控制
這篇文章主要為大家詳細介紹了Openlayers+EasyUI Tree動態(tài)實現(xiàn)圖層控制,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-09-09
JS/jQuery實現(xiàn)獲取時間的方法及常用類完整示例
這篇文章主要介紹了JS/jQuery實現(xiàn)獲取時間的方法及常用類,結合完整實例形式分析了javascript針對日期時間的獲取、轉換、計算與檢測相關操作技巧,需要的朋友可以參考下2019-03-03
取消Bootstrap的dropdown-menu點擊默認關閉事件方法
今天小編就為大家分享一篇取消Bootstrap的dropdown-menu點擊默認關閉事件方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08
JavaScript根據(jù)數(shù)據(jù)生成百分比圖和柱狀圖的實例代碼
這篇文章介紹了JavaScript根據(jù)數(shù)據(jù)生成百分比圖和柱狀圖的實例代碼,有需要的朋友可以參考一下2013-07-07

