成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

淺談Javascript閉包和匿名函數(shù)【1】

cyqian / 945人閱讀

摘要:我們可以用普通函數(shù)內(nèi)部嵌套匿名函數(shù),形成一個閉包來使變量駐留在內(nèi)存中。局部變量閉包為什么要將賦值給變量呢這里我們就要談到匿名函數(shù)調(diào)用問題匿名函數(shù)如何調(diào)用還是上面的例子會將整個函數(shù)體打印出來這樣才調(diào)用了函數(shù)內(nèi)部的匿名函數(shù)看到這里。

閉包含義:

閉包是指有權(quán)訪問另一個函數(shù)作用域中的變量的函數(shù),創(chuàng)建閉包的常見的方式,就是在
一個函數(shù)內(nèi)部創(chuàng)建另一個函數(shù),通過另一個函數(shù)訪問這個函數(shù)的局部變量。

這個時候我們就要談到匿名函數(shù)了.

匿名函數(shù)

匿名函數(shù)就是沒有名字的函數(shù),閉包是可訪問一個函數(shù)作用域里變量的函數(shù)??蠢樱?/p>

function box () {    //這是一個普通函數(shù)
    return "anonymous";    
}
alert(box());

那么匿名函數(shù)是什么呢?看例子:

function () {
    return "anonymous";
}

這個函數(shù)并沒有執(zhí)行?。。?br>如果讓匿名函數(shù)執(zhí)行呢。我們可以將匿名函數(shù)賦值給一個變量:

var box = function (){
    return "anonymous";
};
alert(box());    //anonymous

但是這種表達式有時候并沒有什么含義,那我們可以用自執(zhí)行的方法去調(diào)用匿名函數(shù):

(function () {
    alert("anonymous"); 
})();

匿名函數(shù)如何傳參呢?看例子:

(function (a) {
    alert(a);
})(100);    //alert返回100
匿名函數(shù)和閉包的作用

談到閉包,我們就不得不談到全局變量和局部變量。

全局變量:

全局變量在實際寫項目中個人額不建議使用,因為大量的全局變量會污染代碼,每個模塊都可以去地道用,必將引來很多錯誤。所以推薦變量私有化。

什么是變量私有化?

var a = 100;    //全局變量

function box () {
alert(a);
}
box();    //調(diào)用函數(shù)返回100

通過上面的代碼可以看出,每個函數(shù)內(nèi)都可以調(diào)用外部的局部變量。將a變量變成了公有化的變量,有時候我們并不希望這么做。所以我們可以將變量定義在函數(shù)內(nèi)部使變量變成私有化變量,外部無法訪問到這個變量

function box () {
    var a = 100;    //局部變量
}

alert(a);    //a is not defined

這就完事了么?并沒有??!記住一點:局部變量在每次調(diào)用時都會初始化?。。。ㄖ匾氖虑橛萌齻€感嘆號...)
我們來用一個后置遞增的一個小例子來告訴大家:

function a () {
    var b = 100;
    b++;
    return b;
}
alert(a());    //101
alert(a());    //101

不難看出,每次調(diào)用,變量b都會被初始化,所以每次調(diào)用都會返回101而不是累加。我們可以用普通函數(shù)內(nèi)部嵌套匿名函數(shù),形成一個閉包來使變量駐留在內(nèi)存中。

function a () {
    var b = 100;    //局部變量
    return function () {    //閉包
        b++;
        return b;
    };
}
var c = a();
alert(c());    //101
alert(c());    //102

為什么要將a()賦值給變量c呢?這里我們就要談到匿名函數(shù)調(diào)用問題:
匿名函數(shù)如何調(diào)用?還是上面的例子:

function a () {
    var b = 100;
    return function () {
        return b;
    };
}
alert(a());    //會將整個函數(shù)體打印出來
alert(a()());    //這樣才調(diào)用了函數(shù)內(nèi)部的匿名函數(shù)

看到這里。大家應該理解了為什么要將a()賦值給c變量了吧?因為如果直接使用a()();這樣去調(diào)用,每次調(diào)用還是會初始化局部變量,而我們賦值給變量c,外層函數(shù)被調(diào)用了一次賦值給了C,而每次調(diào)用C去調(diào)用內(nèi)部的匿名函數(shù),從而達到了閉包。

我會在下一章繼續(xù)講閉包,歡迎大家來糾正錯誤及指正!

                                                            Brian Lee

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/80986.html

相關文章

  • 淺談JavaScript閉包的理解

    摘要:關于循環(huán)和閉包當循環(huán)和閉包結(jié)合在一起時,經(jīng)常會產(chǎn)生讓初學者覺得匪夷所思的問題。閉包是一把雙刃劍是比較難以理解和掌握的部分,它十分強大,卻也有很大的缺陷,如何使用它完全取決于你自己。 在談閉包之前,我們首先要了解幾個概念: 什么是函數(shù)表達式? 與函數(shù)聲明有何不同? JavaScript查找標識符的機制 JavaScript的作用域是詞法作用域 JavaScript的垃圾回收機制 先來...

    missonce 評論0 收藏0
  • 淺談JavaScript中的閉包

    摘要:在內(nèi)部,理所當然能訪問到局部變量,但當作為的返回值賦給外的全局變量時,神奇的事情發(fā)生了在全局作用域中訪問到了,這就是閉包。而閉包最神奇的地方就是能在一個函數(shù)外訪問函數(shù)中的局部變量,把這些變量用閉包的形式放在函數(shù)中便能避免污染。 一、閉包是什么? 《JavaScript高級程序設計》中寫道:閉包是指有權(quán)訪問另一個函數(shù)作用域中的變量的函數(shù),如果用下定義的觀點看,這句話就是說閉包是函數(shù),我...

    Riddler 評論0 收藏0
  • 云天視角-淺談閉包

    摘要:函數(shù)在執(zhí)行的時候執(zhí)行函數(shù),將當前的變量對象由于當前的環(huán)境是函數(shù),所以將其活動對象作為變量對象添加到作用域鏈的前端。此時,由于在執(zhí)行,而作用域鏈也存在,所以可以在作用域鏈上進行查找,去訪問的變量。 一、現(xiàn)狀 閉包是jser繞不過的坎,一直在都在說,套用 simpson 的話來說:JavaScript中閉包無處不在,你只需要能夠識別并擁抱它。 閉包是基于詞法作用域書寫代碼時的自然結(jié)果,你甚...

    nanfeiyan 評論0 收藏0
  • 淺談Javascript閉包中作用域及內(nèi)存泄漏問題

    摘要:將作用域賦值給變量這里的作用域是,而不是將作用域賦值給一個變量閉包返回瀏覽器中內(nèi)存泄漏問題大家都知道,閉包會使變量駐留在內(nèi)存中,這也就導致了內(nèi)存泄漏。 上一章我們講了匿名函數(shù)和閉包,這次我們來談談閉包中作用域this的問題。 大家都知道,this對象是在運行時基于函數(shù)的執(zhí)行環(huán)境綁定的,如果this在全局就是[object window],如果在對象內(nèi)部就是指向這個對象,而閉包卻是在運行...

    source 評論0 收藏0
  • 學習JavaScript之內(nèi)存泄漏

    摘要:接上回我寫了一篇關于閉包的博客學習之閉包,最后談到閉包導致的問題時留了一個尾在以下的瀏覽器中會有內(nèi)存泄漏的問題。今天的博客就繼續(xù)探索一下內(nèi)存泄漏的問題。博客地址的前端之路原文鏈接學習之內(nèi)存泄漏 接上回我寫了一篇關于閉包的博客《學習JavaScript之閉包》, 最后談到閉包導致的問題時留了一個尾: 在IE9以下的瀏覽器中會有內(nèi)存泄漏的問題。 今天的博客就繼續(xù)探索一下內(nèi)存泄漏的問題。 淺...

    nodejh 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<