JS回顧-閉包01

時(shí)隔多天,我又準(zhǔn)備更新我得文章了幔亥。

最近看了很多瀏覽器相關(guān)知識(shí)耻讽,就想系統(tǒng)的總結(jié)下學(xué)到的知識(shí)點(diǎn)。
總結(jié)下最近看到知識(shí)點(diǎn)吧帕棉。

之前一直覺(jué)得寫(xiě)閉包容易造成內(nèi)存泄漏针肥,就一直回避這個(gè)問(wèn)題。覺(jué)得不寫(xiě)我一樣能完成預(yù)期的功能香伴,后來(lái)才知道閉包對(duì)于性能優(yōu)化是很有幫助的慰枕,或者說(shuō)想要更上一層樓,這個(gè)問(wèn)題也是繞不開(kāi)的即纲。

先說(shuō)說(shuō)定義吧:
阮一峰:閉包就是能夠讀取其他函數(shù)內(nèi)部變量的函數(shù)
百度:官方對(duì)閉包的解釋是:一個(gè)擁有許多變量和綁定了這些變量的環(huán)境的表達(dá)式(通常是一個(gè)函數(shù))具帮,因而這些變量也是該表達(dá)式的一部分。
《你不知道的JS》一句話(huà)總結(jié)閉包:對(duì)函數(shù)外層的變量持有訪問(wèn)權(quán)崇裁。詳見(jiàn)《你不知道的JS》匕坯。
。拔稳。葛峻。

我也不知道該怎么回答這個(gè)問(wèn)題,暫時(shí)就拿阮一峰的解釋為準(zhǔn)巴比。
兩個(gè)點(diǎn):
1. 是個(gè)函數(shù)
2 能讀到其他函數(shù)內(nèi)容變量

   function f1(){
    var n=999;
    nAdd=function(){n+=1}
    function f2(){
      alert(n);
    }
    return f2;
  }
  var result=f1();
  result(); // 999
  nAdd();
  result(); // 1000

注意這里沒(méi)有用到 “use strict“术奖。所以nAdd不會(huì)報(bào)錯(cuò),反而他會(huì)在window作用域上賦值一個(gè)變量轻绞,也就是全局變量采记。
這里的f2就是一個(gè)閉包函數(shù),他是函數(shù)也能訪問(wèn)到其他函數(shù)內(nèi)部政勃。執(zhí)行結(jié)果唧龄,result()時(shí)候?qū)嶋H執(zhí)行的是返回的f2函數(shù),能訪問(wèn)到f1內(nèi)部的變量奸远,n是999既棺。nAdd執(zhí)行時(shí)候?qū)е耼變?yōu)?00,再次執(zhí)行時(shí)候result()自然就是100.

缺點(diǎn):

從這里就可以看到一個(gè)問(wèn)題懒叛,由于返回的f2函數(shù)要使用f1的內(nèi)部作用域變量n,導(dǎo)致n始終存留在內(nèi)存中丸冕,不會(huì)被垃圾回收機(jī)制回收,當(dāng)然如果此時(shí)還有f1內(nèi)部還有其他變量薛窥,同樣也是不會(huì)被銷(xiāo)毀的胖烛,即使閉包函數(shù)f2沒(méi)有使用---(閉包會(huì)引用外部函數(shù)的整個(gè)活動(dòng)對(duì)象眼姐,這種機(jī)制可能會(huì)導(dǎo)致保存多余的變量而造成內(nèi)存浪費(fèi)),這里存在爭(zhēng)議佩番,也有人說(shuō)---(理論上不回收抄众旗。因?yàn)殚]包中的變量不會(huì)被回收這是閉包的特性之襲一。
但是實(shí)際上不同的瀏覽器實(shí)現(xiàn)的可能不一樣趟畏。一些高端瀏覽器如果確認(rèn)這個(gè)變量沒(méi)有且不會(huì)再被使用百的話(huà)逝钥,也可能將其回收。)鏈接拱镐,所以建議是退出函數(shù)執(zhí)行時(shí),將不使用的局部變量刪除掉持际。

再看一個(gè)例子:

原文鏈接
版權(quán)聲明:本文為CSDN博主「去門(mén)口罰站」的原創(chuàng)文章沃琅,遵循 CC 4.0 BY-SA 版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明蜘欲。

function Outer() {
  var obj = {};
  obj.id = '12345678';
  obj.name = 'aha';
  // ... 假設(shè)經(jīng)過(guò)很多處理過(guò)程益眉,最后obj上帶有很多屬性
  return function() {
    return obj.id;
  };
}

這里的obj始終保留在內(nèi)存中,但是值引用了id一個(gè)屬性姥份,假如obj還有其他一堆屬性郭脂,就難免很浪費(fèi),所以就會(huì)有如下寫(xiě)法澈歉。

版權(quán)聲明:本文為CSDN博主「去門(mén)口罰站」的原創(chuàng)文章展鸡,遵循 CC 4.0 BY-SA 版權(quán)協(xié)議,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明埃难。
原文鏈接

function AnotherOuter() {
  var obj = {};
  obj.id = '12345678';
  obj.name = 'aha';
  // ... 假設(shè)經(jīng)過(guò)很多處理過(guò)程莹弊,最后obj上帶有很多屬性
  var id = obj.id;
  obj = null;
  return function() {
    return id;
  };
}

還有一點(diǎn)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)部變量的值川梅。

例如以下例子疯兼,改變了父函數(shù)的屬性

var name = "The Window";

var object = {
    name: "My Object",

    getNameFunc: function() {
        this.name = "mine";
        return function() {
            return this.name;
        };
    }
};
console.log(object.getNameFunc()()); // The Window 
console.log(object.name) // mine

再看一個(gè)例子


var name = "The Window";

var object = {
    name: "My Object",
    getNameFunc: function() {
        var that = this;
        return function() {
            return that.name;
        };
    }
};
alert(object.getNameFunc()()); // My Object

參考鏈接如下:
[JavaScript高級(jí)]閉包的概念及其應(yīng)用
JavaScript閉包的原理與缺陷
學(xué)習(xí)Javascript閉包(Closure)

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市挑势,隨后出現(xiàn)的幾起案子镇防,更是在濱河造成了極大的恐慌,老刑警劉巖潮饱,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件来氧,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)啦扬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門(mén)中狂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人扑毡,你說(shuō)我怎么就攤上這事胃榕。” “怎么了瞄摊?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵勋又,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我换帜,道長(zhǎng)楔壤,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任惯驼,我火速辦了婚禮蹲嚣,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘祟牲。我一直安慰自己隙畜,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布说贝。 她就那樣靜靜地躺著议惰,像睡著了一般。 火紅的嫁衣襯著肌膚如雪乡恕。 梳的紋絲不亂的頭發(fā)上换淆,一...
    開(kāi)封第一講書(shū)人閱讀 51,443評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音几颜,去河邊找鬼倍试。 笑死,一個(gè)胖子當(dāng)著我的面吹牛蛋哭,可吹牛的內(nèi)容都是我干的县习。 我是一名探鬼主播,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼谆趾,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼躁愿!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起沪蓬,我...
    開(kāi)封第一講書(shū)人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤彤钟,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后跷叉,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體逸雹,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡营搅,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了梆砸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片转质。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖帖世,靈堂內(nèi)的尸體忽然破棺而出休蟹,到底是詐尸還是另有隱情,我是刑警寧澤日矫,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布赂弓,位于F島的核電站,受9級(jí)特大地震影響哪轿,放射性物質(zhì)發(fā)生泄漏拣展。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一缔逛、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧姓惑,春花似錦褐奴、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至唯沮,卻和暖如春脖旱,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背介蛉。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工萌庆, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人币旧。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓践险,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親吹菱。 傳聞我的和親對(duì)象是個(gè)殘疾皇子巍虫,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354

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

  • 一.變量的作用域 要理解閉包,首先必須理解JavaScript特殊的變量作用域鳍刷。 作用域無(wú)非就是兩種:全局作用域和...
    倔強(qiáng)的仙人掌閱讀 161評(píng)論 0 0
  • 一占遥、變量的作用域 要理解閉包,首先必須理解Javascript特殊的變量作用域输瓜。 變量的作用域無(wú)非就是兩種:全局變...
    紫陌蘭溪閱讀 287評(píng)論 0 4
  • 主要鍛煉部位:腿瓦胎、胸芬萍、背、臀凛捏。 橢圓機(jī)15m担忧,拉伸。 靜蹲3.5mx3坯癣。 臥推15x1(18)20x1(18) 1...
    項(xiàng)小喵閱讀 153評(píng)論 0 0
  • 不到兩歲的紫婷 鋪上一張信箋瓶盛,神情專(zhuān)注 仿佛是要寫(xiě)一封長(zhǎng)長(zhǎng)的信 她緊握筆尖 竟是那樣的有模有樣 大人們都笑了 紫婷...
    文伴閱讀 472評(píng)論 0 8
  • 每個(gè)人生來(lái)就開(kāi)始了自己的路 這條路沒(méi)有一個(gè)人走過(guò) 這條路有無(wú)數(shù)可能性 有人會(huì)陪你走 但是 這條路 只屬于你自己 如...
    悠悠思悅閱讀 234評(píng)論 1 2