亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

javascript中閉包概念與用法深入理解

 更新時(shí)間:2016年12月15日 11:40:54   作者:小小小小小亮  
這篇文章主要介紹了javascript中閉包概念與用法,結(jié)合實(shí)例形式深入分析了javascript中閉包的概念、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例分析了javascript中閉包概念與用法。分享給大家供大家參考,具體如下:

1.問(wèn)題的引出,什么時(shí)候會(huì)遇到閉包?

首先因?yàn)镴S是沒(méi)有塊狀作用域的,但是有函數(shù)作用域即函數(shù)作為了局部變量之間的界限,不同函數(shù)內(nèi)的局部變量具有獨(dú)立性,

因?yàn)镴S沒(méi)有塊狀作用域,筆者初學(xué)JS時(shí),在事件的監(jiān)聽(tīng)時(shí),因?yàn)椴焕斫釰S中局部變量的作用域,犯過(guò)不少錯(cuò)誤!

(1)JS中的變量作用域

for(var i=0;i<9;i++)
{
}
alert(i) //輸出9

我們發(fā)現(xiàn),雖然變量i是塊狀區(qū)域for()內(nèi)的一個(gè)局部變量,但是我們?cè)趬K級(jí)作用域for()外,依然可以得到變量i

(2)JS中的函數(shù)作用域

function abc(){
 var a=1;
}
abc();
alert(a);// 會(huì)報(bào)錯(cuò),a is not defined

我們發(fā)現(xiàn),在函數(shù)外調(diào)用函數(shù)后,在函數(shù)外是無(wú)法取到函數(shù)里的變量

總結(jié):通過(guò)(1),(2),我們加深了對(duì)JS中,沒(méi)有塊級(jí)作用域只有函數(shù)作用域的理解!

舉例:如果現(xiàn)在例1:

var a=1
function abc(){
 var a=2;
}
abc();
alert(a) // a=1

特別注意如果例2:

var a=1
function abc(){
a=2;
alert(a);
}
abc();//a=2

對(duì)比例1,不同之處在于例2,中 是“a=2"而不是”var a=2“

區(qū)別在于如果是var a,則表示在函數(shù)中定義變量a,如果是沒(méi)有變量聲明,如果直接a,則表示在全局變量中定義變量a;

2.如果引用函數(shù)內(nèi)部的變量?

由1可知,JS中只存在函數(shù)作用域,那么我們?nèi)绾尾拍茉谀玫胶瘮?shù)中定義的變量呢?

根據(jù)JS的語(yǔ)法規(guī)則:內(nèi)部函數(shù)(或者內(nèi)部對(duì)象)中,可以訪問(wèn)外部函數(shù)中的變量。

什么意思呢?舉例說(shuō)明例1:

function abc(){
 var a=1;
 !function(){
 alert(a)
} ()
} //此時(shí)不會(huì)報(bào)錯(cuò),a=1

再舉一個(gè)例子(內(nèi)部對(duì)象的例子)例2:

var o={
 a=1,
 myfun:function(){
 return this.a
}
}

則alert(o.myfun())得到的值為1,現(xiàn)在我們大概了解了如何訪問(wèn)函數(shù)(或者對(duì)象,其實(shí)函數(shù)的本身也是對(duì)象)中的變量!

3.什么是閉包?

我的理解就定義在一個(gè)函數(shù)內(nèi)部的函數(shù)!

閉包是函數(shù)內(nèi)部與外部之間的橋梁!

即內(nèi)部函數(shù)在定義它的外部使用時(shí),就創(chuàng)建了一個(gè)閉包!

我們知道,一般情況下,當(dāng)函數(shù)被調(diào)用完,內(nèi)存會(huì)被釋放,但是應(yīng)用于函數(shù)閉包比如

function abc1(){
 var a=1;
function abc2(){
 a++;
}
return abc2()
}

當(dāng)我們調(diào)用abc1()函數(shù)后,因?yàn)閍bc1函數(shù)的中又調(diào)用了abc2()函數(shù),因此函數(shù)abc1()中的變量在子函數(shù)中被調(diào)用,所以在父函數(shù)abc1()調(diào)用結(jié)束后

變量a的內(nèi)存空間并不會(huì)被釋放!

為什么GC機(jī)制無(wú)法回收abc1()函數(shù)中的變量a,  因?yàn)槭紫任覀冊(cè)谌种姓{(diào)用了函數(shù)abc1(),我們?cè)O(shè)全局對(duì)象為c,abc1()對(duì)象為b,同時(shí)我們?cè)趯?duì)象b

即函數(shù)abc1()中又調(diào)用了函數(shù)abc2(),設(shè)abc2(0為a。

再次理解這種關(guān)系    c中調(diào)用了b,b中又調(diào)用了a,JS中規(guī)定當(dāng)a,b對(duì)象兩兩互相引用,并且a,b中又有一個(gè)被a,b函數(shù)之外的對(duì)象c引用時(shí),GC機(jī)制不執(zhí)行垃圾回收(變量清空)!

由此我們引出了閉包的重要作用:

如果內(nèi)部函數(shù)在其外部被調(diào)用,則會(huì)產(chǎn)生閉包,閉包用于保存某些變量的值,不會(huì)被垃圾回收機(jī)制回收!

4.閉包的缺點(diǎn)

因?yàn)槭褂瞄]包后,某些變量會(huì)在函數(shù)調(diào)用之后持續(xù)的保持在內(nèi)存中,因此濫用閉包會(huì)導(dǎo)致內(nèi)存泄漏!

5.擴(kuò)展應(yīng)用,加深對(duì)于閉包的理解!

var o={
 a:1;
myfunc:function(){
return function(){
 return this.a;
}
}
alert(o.myfunc()()); // a is not defined
}

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》、《JavaScript切換特效與技巧總結(jié)》、《JavaScript查找算法技巧總結(jié)》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》及《JavaScript遍歷算法與技巧總結(jié)

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • 原生JS實(shí)現(xiàn)日歷組件的示例代碼

    原生JS實(shí)現(xiàn)日歷組件的示例代碼

    本篇文章主要介紹了原生JS實(shí)現(xiàn)日歷組件的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • 爬蟲(chóng)進(jìn)階-JS自動(dòng)渲染之Scrapy_splash組件的使用

    爬蟲(chóng)進(jìn)階-JS自動(dòng)渲染之Scrapy_splash組件的使用

    Splash是一個(gè)Javascript渲染服務(wù)。它是一個(gè)實(shí)現(xiàn)了HTTP API的輕量級(jí)瀏覽器,Splash是用Python和Lua語(yǔ)言實(shí)現(xiàn)的,基于Twisted和QT等模塊構(gòu)建,今天重點(diǎn)給大家介紹js Scrapy_splash組件使用教程,一起看看吧
    2021-09-09
  • wap手機(jī)圖片滑動(dòng)切換特效無(wú)css3元素js腳本編寫(xiě)

    wap手機(jī)圖片滑動(dòng)切換特效無(wú)css3元素js腳本編寫(xiě)

    手機(jī)圖片滑動(dòng)切換,網(wǎng)上有很多這樣的例子,但都借助于其他組件,讓代碼混亂的不行,本例無(wú)css3元素js腳本編寫(xiě),需要的朋友可以參考下
    2014-07-07
  • 每天一篇javascript學(xué)習(xí)小結(jié)(Boolean對(duì)象)

    每天一篇javascript學(xué)習(xí)小結(jié)(Boolean對(duì)象)

    這篇文章主要介紹了javascript中的Boolean對(duì)象知識(shí)點(diǎn),對(duì)Boolean對(duì)象的基本使用方法進(jìn)行解釋,一段很詳細(xì)的代碼介紹,感興趣的小伙伴們可以參考一下
    2015-11-11
  • ECharts事件處理與旭日?qǐng)D實(shí)現(xiàn)

    ECharts事件處理與旭日?qǐng)D實(shí)現(xiàn)

    這篇文章介紹了ECharts事件處理與實(shí)現(xiàn)旭日?qǐng)D的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06
  • 風(fēng)吟的小型JavaScirpt庫(kù) (FY.JS).

    風(fēng)吟的小型JavaScirpt庫(kù) (FY.JS).

    此庫(kù)非常的迷你壓縮之后只有1.54KB.但是卻有類似jquery的語(yǔ)法有COOKIE操作還有DOM以及AJAX跟綁定事件函數(shù).
    2010-03-03
  • 微信小程序?qū)崿F(xiàn)獲取手機(jī)號(hào)60s倒計(jì)時(shí)

    微信小程序?qū)崿F(xiàn)獲取手機(jī)號(hào)60s倒計(jì)時(shí)

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)獲取手機(jī)號(hào)60s倒計(jì)時(shí),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • 基于canvas粒子系統(tǒng)的構(gòu)建詳解

    基于canvas粒子系統(tǒng)的構(gòu)建詳解

    下面小編就為大家?guī)?lái)一篇基于canvas粒子系統(tǒng)的構(gòu)建詳解。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-08-08
  • JavaScript實(shí)現(xiàn)平滑滾動(dòng)效果

    JavaScript實(shí)現(xiàn)平滑滾動(dòng)效果

    頁(yè)面平滑滾動(dòng)是網(wǎng)頁(yè)一種常見(jiàn)的效果,平滑滾動(dòng)的原理其實(shí)很簡(jiǎn)單,無(wú)非就是讓頁(yè)面一種肉眼可見(jiàn)的速度從當(dāng)前位置滾動(dòng)到指定位置,那如何用原生的JS實(shí)現(xiàn)這也效果呢?本文給大家介紹了JavaScript實(shí)現(xiàn)平滑滾動(dòng)效果,需要的朋友可以參考下
    2024-06-06
  • date.parse在IE和FF中的區(qū)別

    date.parse在IE和FF中的區(qū)別

    這個(gè)方法是很常用的,比如在驗(yàn)證輸入日期是否存在時(shí),可以使用它,如果是一個(gè)不存在的日期,則其返回值將是NaN,另外如果要比較兩個(gè)日期的先后,或是計(jì)算兩個(gè)日期相差的天數(shù) ,都可以用到。
    2010-07-07

最新評(píng)論