網(wǎng)頁前端(22)封閉函數(shù)與閉包

封閉函數(shù)

封閉函數(shù)是javascript中匿名函數(shù)的另外一種寫法,創(chuàng)建一個一開始就執(zhí)行而不用命名的函數(shù)田篇。

一般定義的函數(shù)和執(zhí)行函數(shù):
function changecolor(){
    var oDiv = document.getElementById('div1');
    oDiv.style.color = 'red';
}
changecolor();
封閉函數(shù):
(function(){
    var oDiv = document.getElementById('div1');
    oDiv.style.color = 'red';
})();
還可以在函數(shù)定義前加上“~”和“!”等符號來定義匿名函數(shù)
!function(){
    var oDiv = document.getElementById('div1');
    oDiv.style.color = 'red';
}()

閉包

什么是閉包

函數(shù)嵌套函數(shù)洲赵,內(nèi)部函數(shù)可以引用外部函數(shù)的參數(shù)和變量捉偏,參數(shù)和變量不會被垃圾回收機制收回

function aaa(a){      
      var b = 5;      
      function bbb(){
           a++;
           b++;
         alert(a);
         alert(b);
      }
      return bbb;
  }
 var ccc = aaa(2);
 ccc();
 ccc();
改寫成封閉函數(shù)的形式:
var ccc = (function(a){
  var b = 5;
  function bbb(){
       a++;
       b++;
     alert(a);
     alert(b);
  }
  return bbb;
})(2);
ccc();
ccc();
用處

1捷兰、將一個變量長期駐扎在內(nèi)存當(dāng)中,可用于循環(huán)中存索引值

<script type="text/javascript">
    window.onload = function(){
        var aLi = document.getElementsByTagName('li');
        for(var i=0;i<aLi.length;i++)
        {
            (function(i){
                aLi[i].onclick = function(){
                    alert(i);
                }
            })(i);
        }
    }
</script>
......
<ul>
    <li>111</li>
    <li>222</li>
    <li>333</li>
    <li>444</li>
    <li>555</li>
</ul>

2、私有變量計數(shù)器壤躲,外部無法訪問城菊,避免全局變量的污染

<script type="text/javascript">

var count = (function(){
    var a = 0;
    function add(){
        a++;
        return a;
    }
    return add;

})()
count();
count();
var nowcount = count();
alert(nowcount);

</script>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市柒爵,隨后出現(xiàn)的幾起案子役电,更是在濱河造成了極大的恐慌,老刑警劉巖棉胀,帶你破解...
    沈念sama閱讀 212,816評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異冀膝,居然都是意外死亡唁奢,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,729評論 3 385
  • 文/潘曉璐 我一進(jìn)店門窝剖,熙熙樓的掌柜王于貴愁眉苦臉地迎上來麻掸,“玉大人,你說我怎么就攤上這事赐纱〖狗埽” “怎么了?”我有些...
    開封第一講書人閱讀 158,300評論 0 348
  • 文/不壞的土叔 我叫張陵疙描,是天一觀的道長诚隙。 經(jīng)常有香客問我,道長起胰,這世上最難降的妖魔是什么久又? 我笑而不...
    開封第一講書人閱讀 56,780評論 1 285
  • 正文 為了忘掉前任,我火速辦了婚禮效五,結(jié)果婚禮上地消,老公的妹妹穿的比我還像新娘。我一直安慰自己畏妖,他們只是感情好脉执,可當(dāng)我...
    茶點故事閱讀 65,890評論 6 385
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著戒劫,像睡著了一般半夷。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上谱仪,一...
    開封第一講書人閱讀 50,084評論 1 291
  • 那天玻熙,我揣著相機與錄音,去河邊找鬼疯攒。 笑死嗦随,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播枚尼,決...
    沈念sama閱讀 39,151評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼贴浙,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了署恍?” 一聲冷哼從身側(cè)響起崎溃,我...
    開封第一講書人閱讀 37,912評論 0 268
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎盯质,沒想到半個月后袁串,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,355評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡呼巷,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,666評論 2 327
  • 正文 我和宋清朗相戀三年囱修,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片王悍。...
    茶點故事閱讀 38,809評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡破镰,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出压储,到底是詐尸還是另有隱情鲜漩,我是刑警寧澤,帶...
    沈念sama閱讀 34,504評論 4 334
  • 正文 年R本政府宣布集惋,位于F島的核電站孕似,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏芋膘。R本人自食惡果不足惜鳞青,卻給世界環(huán)境...
    茶點故事閱讀 40,150評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望为朋。 院中可真熱鬧臂拓,春花似錦、人聲如沸习寸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,882評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽霞溪。三九已至孵滞,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間鸯匹,已是汗流浹背坊饶。 一陣腳步聲響...
    開封第一講書人閱讀 32,121評論 1 267
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留殴蓬,地道東北人匿级。 一個月前我還...
    沈念sama閱讀 46,628評論 2 362
  • 正文 我出身青樓蟋滴,卻偏偏與公主長得像,于是被迫代替她去往敵國和親痘绎。 傳聞我的和親對象是個殘疾皇子津函,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,724評論 2 351

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