閉包

閉包http://www.ruanyifeng.com/blog/2009/08/learning_javascript_closures.html

前提:

var 和let 的不同

在js嚴(yán)格模式下;

undefined 有變量但是沒(méi)有賦值

1.重復(fù)聲明時(shí),var 的值會(huì)變化,let會(huì)報(bào)? 'letTest' has already been declared 已經(jīng)定義過(guò)了

2.使用未聲明的變量:var 會(huì)說(shuō)undefined 而let會(huì)說(shuō)is not defined

3.變量作用范圍不同

'use strict';

(function() {

var varTest = 'test var OK.';

let letTest = 'test let OK.';

{

var varTest = 'varTest changed.';

let letTest = 'letTest changed.';

}

console.log(varTest); //輸出"varTest changed.",內(nèi)部"{}"中聲明的varTest變量覆蓋外部的letTest聲明

console.log(letTest); //輸出"test let OK.",內(nèi)部"{}"中聲明的letTest和外部的letTest不是同一個(gè)變量

}());

1.如果沒(méi)有聲明var 或者 const 直接 a=12 。則這是個(gè)全局變量

閉包的用途:一個(gè)是前面提到的可以讀取函數(shù)內(nèi)部的變量,另一個(gè)就是讓這些變量的值始終保持在內(nèi)存中。

使用閉包注意:

1)由于閉包會(huì)使得函數(shù)中的變量都被保存在內(nèi)存中,內(nèi)存消耗很大,所以不能濫用閉包,否則會(huì)造成網(wǎng)頁(yè)的性能問(wèn)題,在IE中可能導(dǎo)致內(nèi)存泄露。解決方法是,在退出函數(shù)之前,將不使用的局部變量全部刪除

2)閉包會(huì)在父函數(shù)外部,改變父函數(shù)內(nèi)部變量的值。所以,如果你把父函數(shù)當(dāng)作對(duì)象(object)使用,把閉包當(dāng)作它的公用方法(Public Method),把內(nèi)部變量當(dāng)作它的私有屬性(private value),這時(shí)一定要小心,不要隨便改變父函數(shù)內(nèi)部變量的值。

使用:

function f1(){

var n=999;

nAdd=function(){n+=1}

function f2(){/f2函數(shù)就是閉包,只有函數(shù)內(nèi)部的子函數(shù)才能讀取局部變量,因此可以把閉包簡(jiǎn)單理解成"定義在一個(gè)函數(shù)內(nèi)部的函數(shù)"。

alert(n);

}

return f2;

}

var result=f1();

result(); // 999

nAdd();

result(); // 1000

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容