javascript閉包指的是什么

這篇文章主要介紹了javascript閉包指的是什么,具有一定借鑒價值,需要的朋友可以參考下。希望大家閱讀完這篇文章后大有收獲。下面讓小編帶著大家一起了解一下。

10年積累的網(wǎng)站設(shè)計制作、網(wǎng)站制作經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認識你,你也不認識我。但先網(wǎng)站策劃后付款的網(wǎng)站建設(shè)流程,更有湘陰免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。

JavaScript閉包就是一個內(nèi)部函數(shù)能夠訪問它所在外部函數(shù)作用域中的所有局部變量,參數(shù)或者是其他內(nèi)部函數(shù)。使用閉包需要注意閉包使用增大了內(nèi)存消耗,可能會造成內(nèi)存泄漏

JavaScript中的閉包函數(shù)是javascript的一個重要知識點同樣也是一個難點。簡單的說閉包就是一個函數(shù)能夠訪問其函數(shù)外部作用域的變量。

JavaScript閉包

在JavaScript中允許函數(shù)定義和函數(shù)表達式位于另一個函數(shù)的函數(shù)體中(內(nèi)部函數(shù)),而且內(nèi)部函數(shù)可以訪問它們所在外部函數(shù)聲明中的所有局部變量,參數(shù)以及其他內(nèi)部函數(shù)。當其中一個內(nèi)部函數(shù)被外部函數(shù)以外調(diào)用時就會形成閉包

閉包的特點

閉包函數(shù)具有以下三個方面的特點

(1)函數(shù)嵌套函數(shù)

(2)內(nèi)部的函數(shù)可以訪問外部函數(shù)的變量

(3)參數(shù)和變量都不會被回收

例:

<script>
function f1(){
var n=999;
nAdd=function(){
	n+=1
}
function f2(){
 document.write(n);
    }
    return f2;
  }
  var result=f1();
  result(); 
  nAdd();
  result();
	</script>

輸出結(jié)果為:

javascript閉包指的是什么

上述代碼可以這樣理解:

f1是f2的父函數(shù),而f2被賦給了一個全局變量(return的值),這導(dǎo)致f2始終在內(nèi)存中,而f2的存在依賴于f1,因此f1也始終在內(nèi)存中,不會在調(diào)用結(jié)束后,被垃圾回收機制(garbage collection)回收,這便形成了閉包。

javascript閉包指的是什么

閉包的優(yōu)缺點

優(yōu)點

(1)它可以保護函數(shù)內(nèi)的變量安全 ,實現(xiàn)封裝,防止變量流入其他環(huán)境發(fā)生命名沖突

(2)匿名自執(zhí)行函數(shù)可以減少內(nèi)存消耗

(3)在內(nèi)存中維持一個變量,可以做緩存

缺點

(1)被引用的私有變量不能被銷毀,增大了內(nèi)存消耗,造成內(nèi)存泄漏

(2)由于閉包涉及跨域訪問,所以會導(dǎo)致性能損失,影響代碼執(zhí)行速度

感謝你能夠認真閱讀完這篇文章,希望小編分享javascript閉包指的是什么內(nèi)容對大家有幫助,同時也希望大家多多支持創(chuàng)新互聯(lián),關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,遇到問題就找創(chuàng)新互聯(lián),詳細的解決方法等著你來學(xué)習(xí)!

當前題目:javascript閉包指的是什么
URL網(wǎng)址:http://muchs.cn/article6/pdhdig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供用戶體驗、面包屑導(dǎo)航App設(shè)計、營銷型網(wǎng)站建設(shè)、靜態(tài)網(wǎng)站、云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

h5響應(yīng)式網(wǎng)站建設(shè)