《JavaScript設(shè)計(jì)模式與開發(fā)實(shí)踐》之閉包和高階函數(shù)

閉包和高階函數(shù)

  • 函數(shù)式語言的鼻祖是 LISP
  • JavaScript在設(shè)計(jì)之初參考了 LISP兩大方言之一的 Scheme关顷,引入了 Lambda表達(dá)式邢享、閉包、高階函數(shù)等特性脚粟。

閉包

閉包的形成與變量的作用域以及變量的生存周期密切相關(guān)覆旱。

變量的作用域

  • 變量的作用域,就是指變量的有效范圍核无。
  • 變量的搜索是從內(nèi)到外而非從外到內(nèi)的扣唱。

變量的生命周期

  • 對于全局變量來說,全局變量的生存周期當(dāng)然是永久的厕宗,除非我們主動銷毀這個(gè)全局變量画舌。
  • 對于局部變量來說,當(dāng)退出函數(shù)時(shí)已慢,它們都會隨著函數(shù)調(diào)用的結(jié)束而被銷毀曲聂。
 var foo = function() {
   var a = 1;
   return function() {
     a++;
     alert(a);
   }
 };

var f = foo();
f(); // 輸出:2
f(); // 輸出:3
f(); // 輸出:4
f(); // 輸出:5

變量f 返回了一個(gè)匿名函數(shù)的引用,它可以訪問到 foo()被調(diào)用時(shí)產(chǎn)生的環(huán)境佑惠,而局部變量a 一直處在這個(gè)環(huán)境里朋腋。既然局部變量所在的環(huán)境還能被外界訪問,這個(gè)局部變量就有了不被銷毀的理由膜楷。在這里產(chǎn)生了一個(gè)閉包結(jié)構(gòu)旭咽,局部變量的生命看起來被延續(xù)了。

另一個(gè)經(jīng)典例子赌厅,我們通過循環(huán)來給每個(gè) div 綁定 onclick 事件穷绵,按照索引順序,點(diǎn)擊第 1個(gè) div 時(shí)彈出0特愿,點(diǎn)擊第 2個(gè) div 時(shí)彈出 1仲墨,以此類推。

<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
<div>5</div>
var nodes = document.getElementsByTagName( 'div' );
for ( var i = 0, len = nodes.length; i < len; i++ ){
      nodes[ i ].onclick = function(){
      alert ( i );
    }
};

把每次循環(huán)的 i 值都封閉起來揍障。當(dāng)在事件函數(shù)中順著作用域鏈中從內(nèi)到外查找變量 i 時(shí)目养,會先找到被封閉在閉包環(huán)境中的 i

閉包的更多作用

封裝變量

閉包可以幫助把一些不需要暴露在全局的變量封裝成“私有變量”。

 var mult = function() {
   var a = 2;
   for (var i = 0, l = arguments.length; i < l; i++) {
     a = a * arguments[i];
   }
   return a;
 };
console.log(mult(1, 2, 3)); //輸出 12
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末毒嫡,一起剝皮案震驚了整個(gè)濱河市癌蚁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌兜畸,老刑警劉巖努释,帶你破解...
    沈念sama閱讀 212,686評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異膳叨,居然都是意外死亡洽洁,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,668評論 3 385
  • 文/潘曉璐 我一進(jìn)店門菲嘴,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事龄坪≌汛疲” “怎么了?”我有些...
    開封第一講書人閱讀 158,160評論 0 348
  • 文/不壞的土叔 我叫張陵健田,是天一觀的道長烛卧。 經(jīng)常有香客問我,道長妓局,這世上最難降的妖魔是什么总放? 我笑而不...
    開封第一講書人閱讀 56,736評論 1 284
  • 正文 為了忘掉前任,我火速辦了婚禮好爬,結(jié)果婚禮上局雄,老公的妹妹穿的比我還像新娘。我一直安慰自己存炮,他們只是感情好炬搭,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,847評論 6 386
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著穆桂,像睡著了一般宫盔。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上享完,一...
    開封第一講書人閱讀 50,043評論 1 291
  • 那天灼芭,我揣著相機(jī)與錄音,去河邊找鬼般又。 笑死彼绷,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的倒源。 我是一名探鬼主播苛预,決...
    沈念sama閱讀 39,129評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼笋熬!你這毒婦竟也來了热某?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,872評論 0 268
  • 序言:老撾萬榮一對情侶失蹤胳螟,失蹤者是張志新(化名)和其女友劉穎昔馋,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體糖耸,經(jīng)...
    沈念sama閱讀 44,318評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡秘遏,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,645評論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了嘉竟。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片邦危。...
    茶點(diǎn)故事閱讀 38,777評論 1 341
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡洋侨,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出倦蚪,到底是詐尸還是另有隱情希坚,我是刑警寧澤,帶...
    沈念sama閱讀 34,470評論 4 333
  • 正文 年R本政府宣布陵且,位于F島的核電站裁僧,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏慕购。R本人自食惡果不足惜聊疲,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,126評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望沪悲。 院中可真熱鬧获洲,春花似錦、人聲如沸可训。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,861評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽握截。三九已至飞崖,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間谨胞,已是汗流浹背固歪。 一陣腳步聲響...
    開封第一講書人閱讀 32,095評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留胯努,地道東北人牢裳。 一個(gè)月前我還...
    沈念sama閱讀 46,589評論 2 362
  • 正文 我出身青樓,卻偏偏與公主長得像叶沛,于是被迫代替她去往敵國和親蒲讯。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,687評論 2 351

推薦閱讀更多精彩內(nèi)容