JavaScript閉包詳解
1.?什么是閉包
閉包:函數(shù)本身和該函數(shù)聲明時(shí)所處的環(huán)境狀態(tài)的組合。
也就是說函數(shù)不在其定義的環(huán)境中被調(diào)用,也能訪問定義時(shí)所處環(huán)境的變量。
所以使用閉包,就可以將數(shù)據(jù)與操作該數(shù)據(jù)的函數(shù)相關(guān)聯(lián)。
舉個(gè)例子:
function foo() {
let a = 1;
return function() {
console.log(a);
}
}
let foo1 = foo();
foo1() // 輸出 1
這個(gè)就是一個(gè)閉包的例子,在 foo 中,由于 return 了一個(gè)函數(shù),這個(gè)函數(shù)擁有涵蓋 foo 內(nèi)部作用域的閉包,也就是 a,使得 a 一直存活,不會(huì)在 foo 結(jié)束時(shí)被回收。
2.?閉包的作用
2.1) 記憶性
什么是閉包的記憶性
當(dāng)閉包產(chǎn)生時(shí),函數(shù)所處環(huán)境的狀態(tài)會(huì)始終保持在內(nèi)存中,不會(huì)在外層函數(shù)調(diào)用結(jié)束后,被垃圾回收機(jī)制回收。
舉個(gè)例子:
function foo() {
let a = 0;
return function() {
a ++;
console.log(a);
}
}
let foo1 = foo();
let foo2 = foo();
foo1(); // 1
foo2(); // 1
foo2(); // 2
foo1(); // 2

因?yàn)?a 屬于閉包的一部分,所以當(dāng)閉包產(chǎn)生時(shí),a 所處的環(huán)境狀態(tài)會(huì)保持在內(nèi)存中,不會(huì)隨外層函數(shù)調(diào)用結(jié)束后清除,所以隨著 foo1的使用,a 都會(huì)在內(nèi)存中的值加 1。
然后 foo1 和 foo2 產(chǎn)生的閉包是兩個(gè)獨(dú)立的閉包,它們互不影響。所以 foo2 第二次調(diào)用的時(shí)候,是在它自己第一次調(diào)用后結(jié)果上加 1.
2.2) 模擬私有變量
保證一個(gè)變量只能被進(jìn)行指定操作。
舉個(gè)例子:
function foo() {
let A = 0;
return {
getA : function() {
return A;
},
add : function() {
A ++;
},
del : function() {
A --;
}
}
}
let foo1 = foo();
console.log(foo1.getA()); // 0
foo1.add();
console.log(foo1.getA()); // 1
foo1.del();
console.log(foo1.getA()); // 0

通過閉包,保證了 A 只能被進(jìn)行指定的 加一,減一操作。
3.?閉包的注意點(diǎn)
不能濫用閉包,否則可能會(huì)因?yàn)閮?nèi)存占用過多而造成網(wǎng)頁的性能問題,甚至可能造成內(nèi)存泄漏。
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
JavaScript實(shí)現(xiàn)拖拽簡(jiǎn)單效果
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)拖拽簡(jiǎn)單效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09
微信小程序開發(fā)之組件設(shè)計(jì)規(guī)范
這篇文章主要給大家介紹了關(guān)于微信小程序開發(fā)之組件設(shè)計(jì)規(guī)范的相關(guān)資料,對(duì)剛?cè)腴T學(xué)習(xí)微信小程序的同學(xué)們還是挺有幫助的,需要的朋友可以參考下2021-05-05
JavaScript 異步調(diào)用框架 (Part 1 - 問題 & 場(chǎng)景)
在Ajax應(yīng)用中,調(diào)用XMLHttpRequest是很常見的情況。特別是以客戶端為中心的Ajax應(yīng)用,各種需要從服務(wù)器端獲取數(shù)據(jù)的操作都通過XHR異步調(diào)用完成。2009-08-08
淺析Virtual DOM的概念與其在現(xiàn)代前端框架中的實(shí)踐
這篇文章將深入探討Virtual DOM(虛擬DOM)的概念,分析其對(duì)前端開發(fā)的革新影響,并以此展示前端技術(shù)的深度和魅力,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-12-12
Nuxt.js實(shí)現(xiàn)校驗(yàn)訪問瀏覽器類型的中間件
Nuxt.js 就是一個(gè)Vue的服務(wù)端渲染框架,和React的服務(wù)端渲染框架類似。這篇文章主要介紹了Nuxt.js實(shí)現(xiàn)校驗(yàn)訪問瀏覽器類型的中間件,需要的朋友可以參考下2018-08-08
深入學(xué)習(xí)JavaScript對(duì)象
今天小編就和大家深入學(xué)習(xí)JavaScript對(duì)象,感興趣的小伙伴們可以參考一下,大家一起學(xué)習(xí)。2015-10-10
JavaScript實(shí)現(xiàn)沿五角星形線擺動(dòng)的小圓實(shí)例詳解
這篇文章主要介紹了JavaScript實(shí)現(xiàn)沿五角星形線擺動(dòng)的小圓實(shí)例詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07

