摘韧访铡:
http://www.ruanyifeng.com/blog/2009/08/learning_javascript_closures.html
閉包指有權訪問另一個函數(shù)作用域中的變量的函數(shù)
閉包就是能夠讀取其他函數(shù)內部變量的函數(shù)
作用:
1.可以讀取函數(shù)內部的變量
2.讓這些變量的值始終保存在內存中
函數(shù)內部可以直接讀取全局變量
函數(shù)外部不可以直接讀取函數(shù)內部的變量
- 如何從外部讀取局部變量宠纯?
- 在函數(shù)的內部再定義一個函數(shù)
function f1(){
var n=999;
//f2函數(shù)就是閉包
function f2(){
alert(n);//999
}
return f2
}
var result=f1();
result();
分析:父對象(f1)的所有變量,對子對象(f2)都是可見的婆瓜,反則則不成立
鏈式作用鏈
結構,子對象會一級一級地向上尋找所有對象的變量
只要把f2作為返回值,我們就可以在f1外部讀取它的內存變量
function f1(){
var n=999;
//nAdd沒有用var 聲明治力,所以是一個全局邊變量
nAdd=function(){n+1}//匿名函數(shù)本身也是一個閉包
function f2(){
alert(n);
}
return f2;
}
var result=f1();
result();//999
nAdd();
result();//1000
分析:f1是f2的父函數(shù),而f2被賦給了一個全局變量宵统,這導致f2始終在內存中覆获,而f2依賴于f1瓢省,因此f1也始終在內存中,不會再調用結束后摹量,被垃圾回收機制回收馒胆。
使用閉包的注意點:
1.閉包會使得函數(shù)中的變量都被保存在內存中,內存消耗大
2.閉包會在父函數(shù)外部祝迂,改變父函數(shù)內部的值
- 理解兩個例子
var name="The window";//全局對象
var object={
name="The object",
getNameFunc=function(){
return function(){
return this.name //函數(shù)被調用,this對象綁定到全局
};
}
};
alert(object.getNameFunc()());//The window
var name="The window";
var object={
name:"The object",
getNameFunc=function(){
var that=this;//函數(shù)被作為對象的方法調用当凡,this指代object這個對象
return function(){
return that.name;
};
}
};
alert(object.getNameFunc()());//The object