欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

深入淺出理解JavaScript閉包的功能與用法

 更新時(shí)間:2018年08月01日 11:25:35   作者:winjowind  
這篇文章主要介紹了深入淺出理解JavaScript閉包的功能與用法,結(jié)合實(shí)例形式從變量、函數(shù)的內(nèi)部屬性與作用域鏈分析了javascript閉包的相關(guān)概念、功能與使用技巧,需要的朋友可以參考下

本文實(shí)例講述了JavaScript閉包的功能與用法。分享給大家供大家參考,具體如下:

理解閉包關(guān)鍵是理解JS的對(duì)象的本質(zhì)以及垃圾收集機(jī)制。函數(shù)也是對(duì)象,也有屬性,通常執(zhí)行一個(gè)函數(shù)時(shí),局部變量在函數(shù)執(zhí)行完后,內(nèi)存會(huì)被回收,這是JS的垃圾收集機(jī)制決定的,如果想保存局部變量所占用的內(nèi)存,就必須把保存在另一個(gè)不被回收的變量中,通常是全局變量。函數(shù)在創(chuàng)建時(shí),內(nèi)部屬性[[Scope]]保存了作用域鏈,作用域鏈中包含外部函數(shù)以及全局對(duì)象的變量,被稱為變量對(duì)象。所以把內(nèi)部函數(shù)返回時(shí),由于把函數(shù)保存了,所以內(nèi)部屬性[[Scope]]所保存的變量對(duì)象也就保存了而沒有被回收,因此局部變量也就被保存了。

最簡(jiǎn)單的閉包:

function f1() {
 var i = 0;
 return function () {
 var j = 0;
 i++;
 console.log(i,j);
 };
}
var fn = f1();
fn();//1 0
fn();//2 0

還有諸如給元素添加事件,事件函數(shù)保存著外部函數(shù)的變量,通過這個(gè)特性可以讓按鈕顯示被點(diǎn)擊次數(shù)。

當(dāng)然可以創(chuàng)建多層閉包,最內(nèi)部函數(shù)保存所有外部函數(shù)以及全局對(duì)象的變量,但并不是任何地方都用閉包,因?yàn)槠涫冀K都帶有[[Scope]]屬性,所有比較占內(nèi)存,所以在需要的時(shí)候才用。

閉包在模塊化編程,為函數(shù)或?qū)ο髣?chuàng)建私有變量的時(shí)候非常有用,可以避免全局污染以及變量命名沖突的問題。

值得注意的是因?yàn)?/strong>[[Scope]]與函數(shù)有關(guān),如上述例子,在兩次執(zhí)行f1函數(shù)把返回的函數(shù)保存在不同的變量中,其外部函數(shù)的變量是互不影響的。如:

function f1() {
 var i = 0;
 return function () {
 var j = 0;
 i++;
 console.log(i,j);
 };
}
var fn = f1();
fn();//1 0
fn();//2 0
var fn1 = f1();
fn1();//1 0
fn(); //3 0
fn1();//2 0

感興趣的朋友可以使用在線HTML/CSS/JavaScript前端代碼調(diào)試運(yùn)行工具http://tools.jb51.net/code/WebCodeRun測(cè)試一下上述代碼的運(yùn)行效果,以加深對(duì)javascript閉包的認(rèn)識(shí)。

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript常用函數(shù)技巧匯總》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論