Javascript 設(shè)計模式(二) 閉包
更新時間:2010年05月26日 22:14:34 作者:
本來應(yīng)該是第二章,接口,但因為閉包實在不懂,所以先看看閉包
正文
閉包的概念:
閉包是一個擁有許多變量和綁定了這些變量的環(huán)境的表達(dá)式(通常是一個函數(shù)),因而這些變量也是該表達(dá)式的一部分。
最常見的閉包
function a() {
var i=0;
return function(){
alert(i++);
}
}
var b=a();
for(var i=0;i<3;i++){
b();
}
解釋上面代碼前,先接受一個函數(shù)的創(chuàng)建和執(zhí)行過程
第一步:定義函數(shù),設(shè)置環(huán)境,創(chuàng)建作用域鏈(scope chain)現(xiàn)a為全局變量,則a的作用域鏈中只有window
第二步:執(zhí)行a, 首先創(chuàng)建作用域(a.scope=a),然后創(chuàng)建活動對象(callObject),并將callObject放入a的作用域鏈的頂端,因此a的作用域鏈中含有兩個對象(a和window)
第三步:在活動對象上添加一個arguments屬性,保存調(diào)用a時的參數(shù)值
第四步:將形參和內(nèi)部變量賦值到活動對象a上
javascriptGC原理:如果一個對象不再被引用,那么這個對象會被GC回收。如果兩個對象無干擾的互相引用,那么這兩個對象也會被回收。
總結(jié):
1、首先定義a時,創(chuàng)建了a的作用域鏈(scope chain)
2、(var b=a())執(zhí)行a時,創(chuàng)建作用域a.scope=a,并創(chuàng)建callObject對象添加a的作用域中
3、a對象上添加了arguments屬性,并將i和return函數(shù)賦值給活動對象
4、執(zhí)行a時將b指向了a的ruturn函數(shù)值,在b中又引用的a中的局部變量i,因此不符合GC的回收標(biāo)準(zhǔn),活動對象a沒有被回收,因此b訪問i是第一次訪問的對象,并且只有在b中才能訪問
閉包的概念:
閉包是一個擁有許多變量和綁定了這些變量的環(huán)境的表達(dá)式(通常是一個函數(shù)),因而這些變量也是該表達(dá)式的一部分。
最常見的閉包
復(fù)制代碼 代碼如下:
function a() {
var i=0;
return function(){
alert(i++);
}
}
var b=a();
for(var i=0;i<3;i++){
b();
}
解釋上面代碼前,先接受一個函數(shù)的創(chuàng)建和執(zhí)行過程
第一步:定義函數(shù),設(shè)置環(huán)境,創(chuàng)建作用域鏈(scope chain)現(xiàn)a為全局變量,則a的作用域鏈中只有window
第二步:執(zhí)行a, 首先創(chuàng)建作用域(a.scope=a),然后創(chuàng)建活動對象(callObject),并將callObject放入a的作用域鏈的頂端,因此a的作用域鏈中含有兩個對象(a和window)
第三步:在活動對象上添加一個arguments屬性,保存調(diào)用a時的參數(shù)值
第四步:將形參和內(nèi)部變量賦值到活動對象a上
javascriptGC原理:如果一個對象不再被引用,那么這個對象會被GC回收。如果兩個對象無干擾的互相引用,那么這兩個對象也會被回收。
總結(jié):
1、首先定義a時,創(chuàng)建了a的作用域鏈(scope chain)
2、(var b=a())執(zhí)行a時,創(chuàng)建作用域a.scope=a,并創(chuàng)建callObject對象添加a的作用域中
3、a對象上添加了arguments屬性,并將i和return函數(shù)賦值給活動對象
4、執(zhí)行a時將b指向了a的ruturn函數(shù)值,在b中又引用的a中的局部變量i,因此不符合GC的回收標(biāo)準(zhǔn),活動對象a沒有被回收,因此b訪問i是第一次訪問的對象,并且只有在b中才能訪問
您可能感興趣的文章:
- javascript設(shè)計模式 接口介紹
- javascript設(shè)計模式 封裝和信息隱藏(上)
- javascript學(xué)習(xí)筆記(九) js對象 設(shè)計模式
- JavaScript 設(shè)計模式 安全沙箱模式
- JavaScript 設(shè)計模式 富有表現(xiàn)力的Javascript(一)
- javascript 設(shè)計模式之單體模式 面向?qū)ο髮W(xué)習(xí)基礎(chǔ)
- JavaScript 設(shè)計模式之組合模式解析
- 小議javascript 設(shè)計模式 推薦
- JavaScript 設(shè)計模式學(xué)習(xí) Factory
- JavaScript 設(shè)計模式學(xué)習(xí) Singleton
- 一種JavaScript的設(shè)計模式
- javascript設(shè)計模式之工廠模式示例講解
相關(guān)文章
JS實現(xiàn)iframe自適應(yīng)高度的方法示例
這篇文章主要介紹了JS實現(xiàn)iframe自適應(yīng)高度的方法,結(jié)合實例形式分析了JS實現(xiàn)iframe高度自適應(yīng)的實現(xiàn)技巧,并給出了項目示例供大家參考,需要的朋友可以參考下2017-01-01小程序按鈕避免多次調(diào)用接口和點擊方案實現(xiàn)(不用showLoading)
這篇文章主要介紹了小程序按鈕避免多次調(diào)用接口和點擊方案實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04JS數(shù)據(jù)結(jié)構(gòu)與算法中的隊列結(jié)構(gòu)詳解
隊列指的是一種受限的線性表,先進(jìn)先出,今天通過本文帶領(lǐng)大家認(rèn)識隊列及隊列的應(yīng)用,對JS數(shù)據(jù)結(jié)構(gòu)與算法-隊列結(jié)構(gòu)相關(guān)知識感興趣的朋友一起看看吧2022-11-11