JavaScript中的閉包
1、什么是閉包
閉包,官方對閉包的解釋是:一個擁有許多變量和綁定了這些變量的環(huán)境的表達式(通常是一個函數(shù)),因而這些變量也是該表達式的一部分。
簡單的說,Javascript允許使用內(nèi)部函數(shù)---即函數(shù)定義和函數(shù)表達式位于另一個函數(shù)的函數(shù)體內(nèi)。而且,這些內(nèi)部函數(shù)可以訪問它們所在的外部函數(shù)中聲明的所有局部變量、參數(shù)和聲明的其他內(nèi)部函數(shù)。當(dāng)其中一個這樣的內(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中的閉包,希望對大家有所幫助!
相關(guān)文章
JavaScript之DOM_動力節(jié)點Java學(xué)院整理
由于HTML文檔被瀏覽器解析后就是一棵DOM樹,要改變HTML的結(jié)構(gòu),就需要通過JavaScript來操作DOM。始終記住DOM是一個樹形結(jié)構(gòu)。2017-07-07調(diào)試Javascript代碼(瀏覽器F12及VS中debugger關(guān)鍵字)
目前,常用的瀏覽器IE、Chrome、Firefox都有相應(yīng)的腳本調(diào)試功能下面我就介紹如何在瀏覽器/VS中調(diào)試我們的JS代碼,感興趣的你可不要走開啊,希望本文對你有所幫助2013-01-01JS點擊某個圖標(biāo)或按鈕彈出文件選擇框的實現(xiàn)代碼
本文給大家介紹js點擊點擊某個圖標(biāo)或按鈕彈出文件選擇框的實現(xiàn)代碼,代碼簡單易懂,非常不錯,感興趣的朋友可以參考下2016-09-09Javascript中apply、call、bind的巧妙使用
Javascript中apply、call、bind都是為了改變函數(shù)體內(nèi)部 this 的指向。下面通過本文重點給大家介紹js中apply,call,bind的巧妙使用方法,感興趣的朋友一起學(xué)習(xí)吧2016-08-08JavaScript Tips 使用DocumentFragment加快DOM渲染速度
大家在開發(fā)JavaScript應(yīng)用的時候,如果遇到這種大量節(jié)點的情況,不妨將DocumentFragment作為一個備選的方案。2010-06-06