您好,登錄后才能下訂單哦!
這篇文章主要介紹JavaScript中閉包有什么用,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
閉包:函數本身和該函數聲明時所處的環境狀態的組合。
也就是說函數不在其定義的環境中被調用,也能訪問定義時所處環境的變量。
所以使用閉包,就可以將數據與操作該數據的函數相關聯。
舉個例子:
function foo() { let a = 1; return function() { console.log(a); } } let foo1 = foo(); foo1() // 輸出 1
這個就是一個閉包的例子,在 foo 中,由于 return 了一個函數,這個函數擁有涵蓋 foo 內部作用域的閉包,也就是 a,使得 a 一直存活,不會在 foo 結束時被回收。
什么是閉包的記憶性
當閉包產生時,函數所處環境的狀態會始終保持在內存中,不會在外層函數調用結束后,被垃圾回收機制回收。
舉個例子:
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
因為 a 屬于閉包的一部分,所以當閉包產生時,a 所處的環境狀態會保持在內存中,不會隨外層函數調用結束后清除,所以隨著 foo1的使用,a 都會在內存中的值加 1。
然后 foo1 和 foo2 產生的閉包是兩個獨立的閉包,它們互不影響。所以 foo2 第二次調用的時候,是在它自己第一次調用后結果上加 1.
保證一個變量只能被進行指定操作。
舉個例子:
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 只能被進行指定的 加一,減一操作。
不能濫用閉包,否則可能會因為內存占用過多而造成網頁的性能問題,甚至可能造成內存泄漏。
以上是“JavaScript中閉包有什么用”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。