您好,登錄后才能下訂單哦!
本篇內(nèi)容主要講解“JavaScript閉包c(diǎn)losure有什么作用”,感興趣的朋友不妨來看看。本文介紹的方法操作簡單快捷,實(shí)用性強(qiáng)。下面就讓小編來帶大家學(xué)習(xí)“JavaScript閉包c(diǎn)losure有什么作用”吧!
閉包(closure
)指有權(quán)訪問另一個函數(shù)作用域中變量的函數(shù)。 ----- JavaScript
高級程序設(shè)計
簡單理解閉包就是一個函數(shù),他的特點(diǎn)是:一個作用域可以訪問另外一個函數(shù)內(nèi)部的局部變量。
舉個簡單的例子:
比如說我們現(xiàn)在有一個函數(shù),在他的內(nèi)部我們定義了一個局部變量,如果別的作用域可以訪問這個局部變量,就產(chǎn)生了閉包。所以我們在該函數(shù)內(nèi)部再定義另一個函數(shù),看看里面的函數(shù)作用域是否可以訪問外函數(shù)中的局部變量。
function f1(){ var num = 10; function f2(){ console.log(num); } f2(); } f1();
打印的結(jié)果為:
可以發(fā)現(xiàn)成功將值打印出來,所以就產(chǎn)生了閉包。
但是有的讀者可能就有疑問:f2函數(shù)本身就在f1函數(shù)的內(nèi)部,它本來就可以使用父函數(shù)的變量。那我們再在f1函數(shù)的外部的作用域訪問該變量,看看結(jié)果又是如何。
我們將f2函數(shù)的調(diào)用改為f1函數(shù)的返回值,然后在函數(shù)外面調(diào)用f1函數(shù),如下:
function f1(){ var num = 10; function f2(){ console.log(num); } return f2() } var f = f1(); f();
此時,就相當(dāng)于f1外部的作用域訪問其內(nèi)部函數(shù)的變量。打印結(jié)果為:
可以發(fā)現(xiàn),這里也可以使用其內(nèi)部的局部變量,閉包產(chǎn)生。
所以可以得出結(jié)論:
閉包: 一個作用域可以訪問另外一個函數(shù)內(nèi)部的局部變量。
我們知道,在函數(shù)內(nèi)部定義的局部變量,只能在函數(shù)內(nèi)部可以使用,并且當(dāng)我們使用完成后它就會被銷毀,但是有閉包以后,這個局部變量就會在函數(shù)外部使用并且要等它的外部調(diào)用者調(diào)用完畢后才會被銷毀,所以閉包的作用就是:延伸了變量的作用范圍。
到此,相信大家對“JavaScript閉包c(diǎn)losure有什么作用”有了更深的了解,不妨來實(shí)際操作一番吧!這里是億速云網(wǎng)站,更多相關(guān)內(nèi)容可以進(jìn)入相關(guān)頻道進(jìn)行查詢,關(guān)注我們,繼續(xù)學(xué)習(xí)!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。