|
摘要
本系列博文主要談一些在 Javascript 使用中經(jīng)常會混淆的高級應(yīng)用,包括: prototype, closure, scope, this關(guān)鍵字. 對于一個需要提高自己Javascript水平的程序員,這些都是必須要掌握的.本節(jié)主要介紹closure.
什么是closure?
一種定義是:A "closure" is an expression (typically a function) that can have free variables together with an environment that binds those variables (that "closes" the expression).
我的理解是: closure 是一個表達式(通常是一個函數(shù)), 這個表達式與一個 環(huán)境 共享著一些自由變量, 而這個 環(huán)境 則 綁定 著那些自由變量(或者說 結(jié)束 這個表達式, 這也是所謂closure 的名字由來). 所謂的 環(huán)境 就是一個更大的block, 所有的自由變量在這個 block 中 聲明(有意義). 而 綁定 也就是指這些自由變量的作用域就是這個環(huán)境.
舉個簡單的例子:
var flag = false; //調(diào)試開關(guān)
// env 既是所謂的環(huán)境
// 而inner就是所謂的表達式, name即是所謂的自由變量
function env() //整個env可以看作是一個closure
{
var name = "zhutao";
function inner()
{
return name + " is a student.";
}
return inner; //返回的是一個內(nèi)部函數(shù)
}//closure結(jié)束
flag = true;
if (flag)
{
// 此處是最神奇的地方, 代碼執(zhí)行在此處, inner函數(shù)其實已經(jīng)出了env的body,
// 而仍然能夠被引用, 這就是所謂形成了一個 closure
var inner_func_ref = env(); // 這時候inner_func_ref引用的就是inner()函數(shù)對象
alert(inner_func_ref()); // zhutao is a student.
}
it知識庫:javascript必知必會之closure,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。