JavaScript中的閉包
1、什么是閉包
閉包,官方對閉包的解釋是:一個擁有許多變量和綁定了這些變量的環(huán)境的表達式(通常是一個函數(shù)),因而這些變量也是該表達式的一部分。
簡單的說,Javascript允許使用內(nèi)部函數(shù)---即函數(shù)定義和函數(shù)表達式位于另一個函數(shù)的函數(shù)體內(nèi)。而且,這些內(nèi)部函數(shù)可以訪問它們所在的外部函數(shù)中聲明的所有局部變量、參數(shù)和聲明的其他內(nèi)部函數(shù)。當其中一個這樣的內(nèi)部函數(shù)在包含它們的外部函數(shù)之外被調(diào)用時,就會形成閉包。
閉包的特點
1 函數(shù)嵌套函數(shù)
2 函數(shù)內(nèi)部可以引用外部的參數(shù)和變量
3 參數(shù)和變量不會被垃圾回收機制回收
一般函數(shù)執(zhí)行完畢后,局部活動對象就被銷毀,內(nèi)存中僅僅保存全局作用域。但閉包的情況不同!
function fn(){
var a = ;
function fn(){
//可以訪問fn中定義的a值
alert( a++ );
}
fn();
}
fn(); //
fn(); //
function fn(){
var a = ;
function fn(){
//可以訪問fn中定義的a值
alert( a++ );
}
return fn;//
}
var f = fn();
f(); // 執(zhí)行完后a還在內(nèi)存中
f(); //
f = null; //a被回收
以上所述是小編給大家介紹JavaScript中的閉包,希望對大家有所幫助!
相關文章
sass 中使用 /deep/ 修改 elementUI 組件樣式報錯
這篇文章主要介紹了sass 中使用 /deep/ 修改 elementUI 組件樣式報錯的解決方案,嘗試用 ::v-deep 替換 /deep/ ,成功解決了問題,感興趣的朋友跟隨小編一起看看吧2024-02-02
詳解JavaScript中js對象與JSON格式字符串的相互轉換
本篇文章主要介紹了JavaScript中js對象與JSON格式字符串的相互轉換,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-02-02

