閉包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