你知道嗎?在 JavaScript 中,所有函數本質上都是閉包(只有一個例外)。真的,讓我們來了解一下它是如何運作的。
閉包是與其詞法引用捆綁在一起的函數。雖然這是正式定義,但閉包的真正意義是什麼?在深入了解閉包之前,了解一流函數是有益的,因為它提供了基礎知識,可以幫助您掌握閉包的工作原理。
首先要了解的關鍵概念:
1。一等函數: 可以指派給變數、作為參數傳遞並從函數傳回的函數。
2.函數作用域: 函數可以從自己的作用域和周圍(外部)作用域存取變數。
3.執行上下文: 每次呼叫函數時,都會建立一個新的執行上下文。這包括變數環境和作用域鏈。
通常,在函數內建立的變數的作用域僅限於該函數,並在函數完成執行後立即銷毀。例如,考慮一個名為 premiumContentAccess 的函數,它包含兩個變數:articlesAllowedToAccess 和 currentlyAccessed.
function premiumContentAccess() { let articlesAllowedToAccess = 3; let currentlyAccessed = 0; } premiumContentAccess();
執行premiumContentAccess時,會建立局部變數articlesAllowedToAccess和currentlyAccessed。一旦函數執行完成,這些變數就會超出範圍並有資格進行垃圾回收,這意味著它們被有效地銷毀並且之後無法存取。
即使在執行premiumContentAccess之後,是否可以保留對這些變數的存取權限?到這裡就結束了。
什麼是關閉?
當傳回一個可以存取其周圍(外部)變數的函數時,就會形成閉包。這些變數引用與函數捆綁在一起,使它們能夠持續存在。
function premiumContentAccess() { let articlesAllowedToAccess = 3; let currentlyAccessed = 0; function accessArticle() { if (currentlyAccessed >= articlesAllowedToAccess) { return 'Premium Article Access Reached'; } currentlyAccessed++; return 'Article accessed'; } return accessArticle; } let accessArticle = premiumContentAccess(); console.log(accessArticle()); // Outputs: Article accessed console.log(accessArticle()); // Outputs: Article accessed console.log(accessArticle()); // Outputs: Article accessed console.log(accessArticle()); // Outputs: Premium Article Access Reached
範例分解
1。外部函數: premiumContentAccess() 是定義變數 articlesAllowedToAccess 和 currentlyAccessed.
的外部函數
2.內部函數: accessArticle 是從其詞法範圍存取變數的內部函數,該變數在外部函數中定義。
3.閉包: 當呼叫premiumContentAccess() 時,它回傳accessArticle函數,保留對變數articlesAllowedToAccess 的訪問,即使在外部函數執行完畢後也是如此。
4.狀態保留:
閉包允許 accessArticle 維護自己的狀態(有關已訪問的文章數)。每次呼叫 accessArticle 都會修改 currentlyAccessed,該值會因關閉而保留。
正如我們在開始時提到的,所有函數本質上都是閉包。
也就是說:它們透過隱藏的
[[Environment]]屬性自動保留對其建立上下文的引用,從而允許它們的程式碼存取外部變數。
例外:使用 new Function 建構子建立的函數將 [[Environment]] 設定為全域上下文而不是建立上下文。
感謝您的閱讀!我希望您覺得這個部落格內容豐富且引人入勝。如果您發現任何不準確之處或有任何回饋,請隨時告訴我。
以上是閉包 - Javascript的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Python和JavaScript的主要區別在於類型系統和應用場景。 1.Python使用動態類型,適合科學計算和數據分析。 2.JavaScript採用弱類型,廣泛用於前端和全棧開發。兩者在異步編程和性能優化上各有優勢,選擇時應根據項目需求決定。

選擇Python還是JavaScript取決於項目類型:1)數據科學和自動化任務選擇Python;2)前端和全棧開發選擇JavaScript。 Python因其在數據處理和自動化方面的強大庫而備受青睞,而JavaScript則因其在網頁交互和全棧開發中的優勢而不可或缺。

Python和JavaScript各有優勢,選擇取決於項目需求和個人偏好。 1.Python易學,語法簡潔,適用於數據科學和後端開發,但執行速度較慢。 2.JavaScript在前端開發中無處不在,異步編程能力強,Node.js使其適用於全棧開發,但語法可能複雜且易出錯。

javascriptisnotbuiltoncorc; sanInterpretedlanguagethatrunsonenginesoftenwritteninc.1)JavascriptwasdesignedAsignedAsalightWeight,drackendedlanguageforwebbrowsers.2)Enginesevolvedfromsimpleterterpretpretpretpretpreterterpretpretpretpretpretpretpretpretpretcompilerers,典型地,替代品。

JavaScript可用於前端和後端開發。前端通過DOM操作增強用戶體驗,後端通過Node.js處理服務器任務。 1.前端示例:改變網頁文本內容。 2.後端示例:創建Node.js服務器。

選擇Python還是JavaScript應基於職業發展、學習曲線和生態系統:1)職業發展:Python適合數據科學和後端開發,JavaScript適合前端和全棧開發。 2)學習曲線:Python語法簡潔,適合初學者;JavaScript語法靈活。 3)生態系統:Python有豐富的科學計算庫,JavaScript有強大的前端框架。

JavaScript框架的強大之處在於簡化開發、提升用戶體驗和應用性能。選擇框架時應考慮:1.項目規模和復雜度,2.團隊經驗,3.生態系統和社區支持。

引言我知道你可能會覺得奇怪,JavaScript、C 和瀏覽器之間到底有什麼關係?它們之間看似毫無關聯,但實際上,它們在現代網絡開發中扮演著非常重要的角色。今天我們就來深入探討一下這三者之間的緊密聯繫。通過這篇文章,你將了解到JavaScript如何在瀏覽器中運行,C 在瀏覽器引擎中的作用,以及它們如何共同推動網頁的渲染和交互。 JavaScript與瀏覽器的關係我們都知道,JavaScript是前端開發的核心語言,它直接在瀏覽器中運行,讓網頁變得生動有趣。你是否曾經想過,為什麼JavaScr


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

Atom編輯器mac版下載
最受歡迎的的開源編輯器

SublimeText3 Linux新版
SublimeText3 Linux最新版

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!