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