閉包

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

前提:

var 和let 的不同

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

undefined 有變量但是沒有賦值

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

2.使用未聲明的變量:var 會說undefined 而let會說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不是同一個變量

}());

1.如果沒有聲明var 或者 const 直接 a=12 。則這是個全局變量

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

使用閉包注意:

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

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

使用:

function f1(){

var n=999;

nAdd=function(){n+=1}

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

alert(n);

}

return f2;

}

var result=f1();

result(); // 999

nAdd();

result(); // 1000

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

推薦閱讀更多精彩內(nèi)容

  • 閉包(closure)是Javascript語言的一個難點,也是它的特色,很多高級應(yīng)用都要依靠閉包實現(xiàn)。 一、變量...
    zock閱讀 1,085評論 2 6
  • ● 閉包基礎(chǔ) ● 閉包作用 ● 閉包經(jīng)典例子 ● 閉包應(yīng)用 ● 閉包缺點 ● 參考資料 1、閉包基礎(chǔ) 作用域和作...
    lzyuan閱讀 962評論 0 0
  • 閉包(closure)是Javascript語言的一個難點,也是它的特色,很多高級應(yīng)用都要依靠閉包實現(xiàn)。 一、變量...
    zouCode閱讀 1,284評論 0 13
  • 無論好壞,都會過去的。 原創(chuàng)文 | 是熱河 (清風(fēng)浪港手寫鋪原創(chuàng)文,未經(jīng)授權(quán)請勿轉(zhuǎn)載) “說起來,你算是綁架案重要...
    清風(fēng)浪港手寫鋪閱讀 354評論 0 0
  • 在《如何打造你的獨特觀點》一書中,日本作家齋藤孝就提到:“從企業(yè)招聘的要求來看,企業(yè)也更傾向于聘用’有想法’的人。...
    Amoy_Amon閱讀 155評論 3 3