成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

一個基本的面試問題:可以解釋一下什么是閉包嗎?

開發 前端
在計算機科學中,閉包是一個有自己環境的函數,,并且在該環境中至少有一個變量。

面對面試問題,我們總是如臨大敵。

令人憎惡的面試問題

之前,我參加了一個面試,其中工程團隊要求我解釋閉包的含義。當然,這不是我第一次被問到這個術語,但老實說,我還是有些慌張。

眾所周知,閉包這個術語因難以定義而臭名昭著。

面試后,我對自己仍恐懼這個問題感到沮喪。我下定決心,要徹底弄明白閉包的含義。本篇博客將帶領大家來看看我的經歷。

匿名函數和IIFE不是閉包

文章開始前,我先闡明不會涉及的內容。在ES6之前的時代,閉包的常見用例是用于模仿私有方法的匿名函數/ IIFE(立即調用函數表達式),這些方法不是JavaScript所特有的。

通過在ES6中引入let 、const的引入和以及模塊,很大程度上解決了var 的局限性所導致的這種情況和其他類似的用例。IIFE包括閉包,但不是閉包。

匿名函數也不是閉包。

  1. anonymousFunc !== closure&& IIFE !== closure // true 

學習這些用例很重要。如果你理解過去使用閉包的方式,就能理解現在如何使用閉包。

更別說還有許多ES5遺留代碼。但是這不是今天要講述的內容。既然已經說明,那一起來深入了解吧。

閉包的概念

[[316516]]

來源:Pexels

在計算機科學中,閉包是一個有自己環境的函數,并且在該環境中至少有一個變量。MDN指出:

“在JavaScript中,每當創建一個函數,閉包便產生。”

因此,函數和閉包是緊密聯系的。每創建一個函數,都在構建一個閉包,這意味著你可能一直在創建它們,只是自己沒有意識到而已。MDN繼續指出:

“閉包是將函數與其引用的周邊狀態綁定在一起形成(封裝)的組合”,這將我們帶到了作用域。

它與作用域有什么關系?

從前面的引用中更加深入地去探究周圍狀態這個術語。在JavaScript函數中,周圍狀態稱為作用域。

創建JS文件時,環境就是程序的全局作用域。創建函數時,它有自己的作用域。

可以把全局作用域視為國家。一個國家有許多城市,每個城市都封閉在自己的邊界線內。同樣地,在程序的特定部分中,我們會發現包含在局部作用域內的對象。

Javascript有兩個局部作用域:函數作用域和塊級作用域。

  1. functionencourage() { 
  2.  const positivity ='You got this!'
  3. //  positivity has function scope 
  4.  const negativity ='I don't got this.'; 
  5. //  negativity has block scope 

函數存在于并能訪問全局作用域,但是在函數內聲明的任何內容僅存在于并只能訪問函數作用域,而非全局作用域。

同樣地,如果在代碼的任何位置用大括號括起一個變量,那么該變量也將被封閉,屬于塊級作用域。

閉包和作用域

將閉包視為封閉函數的傳感門可能更容易理解。例如,創建新函數時,該函數的閉包到處查看并記下它的環境,即作用域。

  1. function highestBoxOffice() { 
  2.    const context = “The highest grossingmovie of all time is “; 
  3.       return context + “Avengers:Endgame”; 

即使函數沒有子函數,它仍然有閉包。閉包并不僅存在于嵌套函數中。在變量context的案例中,該函數的閉包到處察看并發現其中存在變量。

嵌套函數中的閉包

[[316517]]

來源:Pexels

如果創建一個嵌套函數,該函數的閉包發現它所在的父函數的墻壁。父函數的作用域是嵌套函數的外部作用域,包括父函數中的變量。

  1. functionhighestBoxOffice(movies) { 
  2.    returnfunctiongenreTopGross(genre) { 
  3.       returnMath.Max(…movies.genre.boxOffice) 
  4.    } 

這是閉包真正發揮作用的地方。函數 genreTopGross()含有閉包。其閉包向內看,發現其內部作用域,包含returnMath.Max(…movies.genre.boxOffice)。

它也向外看,發現其外部作用域,標志著它在函數highestBoxOffice()中。它還可以查看并訪問傳遞到其父函數的所有參數。現在來傳遞一個參數。

  1. functionhighestBoxOffice(movies) { 
  2.    returnfunctiongenreTopGross(genre) { 
  3.       returnMath.Max(…movies[genre].boxOffice) 
  4.    } 
  5. const topGrossing =highestBoxOffice(domesticMoviesObj) 

如你所見,已經聲明了一個新變量topGrossing()并且賦予它highestBoxOffice(domesticMoviesObj)的值。

目前,topGrossing是未定義的,但是現在采取下一步:

  1. functionhighestBoxOffice(movies) { 
  2.    returnfunctiongenreTopGross(genre) { 
  3.       returnMath.Max(…movies[genre].boxOffice) 
  4.    } 
  5. const topGrossing =highestBoxOffice(domesticMoviesObj) 
  6. topGrossing("Romantic  Comedy")// "Pretty Woman" 

引用topGrossing(),并將“Romantic Comedy”作為參數進行傳遞。現在閉包的用處展現出來了!

. genreTopGross()函數的內部作用域需要movies參數,該參數位于domesticMoviesObj參數的外部作用域,需要通過閉包來進入。

這使代碼成功執行并返回正在尋找的值。

閉包和作用域鏈

在JavaScript中,每個變量在首次創建時,都屬于一個特定的詞法作用域。

在書面程序內,每個變量的作用域都通過作用域鏈連接起來,全局作用域總是位于該鏈的頂端。

JavaScript編譯器遍歷這條鏈。然而,該編譯器就像汽車,僅逆向運行,從不正向運行。

使用變量時,編譯器返回到作用域鏈,直到找出該變量的入口。

因此,genreTopGross()函數使用movies變量時,JavaScript沒有在genreTopGross()作用域中發現 movies。所以,JavaScript沿著在作用域鏈中向上移動,直到找到傳遞到highestBoxOffice()的movies。

這與閉包有什么關系呢?

閉包只提供從內部到外部作用域的訪問,而不能提供從外部到內部作用域的訪問。

因此,如果在幾個嵌套函數中聲明并定義一個變量,卻在父函數的外部作用域中使用,編譯器將返回一個未定義的錯誤。記住,汽車只會逆向行駛。

結論

[[316518]]

來源:Pexels

如你所見,理解閉包需要對函數、作用域以及作用域鏈有著扎實深入的理解,這正是面試者提問時所期待的。

本文只解釋了閉包的定義,但并未涉及它們的大量用例。如果您理解了這一點,應該能更深入地研究這些用例,而不會感到完全迷失。

若沒有其他問題,希望本文能夠提供簡單的基礎或簡明的概述,使大家不再對閉包感到驚慌。

現在,去拿下面試吧!哦耶~

 

責任編輯:趙寧寧 來源: 讀芯術
相關推薦

2011-01-18 13:45:58

2021-08-28 09:06:11

Dubbo架構服務

2020-08-13 08:43:24

TCP固定窗口滑動窗口

2020-07-06 08:00:26

MySQL程序員SQL

2025-06-25 10:17:48

2025-02-28 09:14:09

JavaNIO機制

2023-05-22 10:09:21

FlexboxCSS3

2025-03-10 07:05:07

2019-07-15 11:04:37

Spring BootTomcat開發

2021-12-02 06:08:36

物聯網IOT物聯網技術

2017-09-15 10:36:17

前端JavaScript面試題

2021-08-02 07:59:47

技術動圖數列

2021-08-02 07:59:21

單調棧題目

2019-11-07 21:51:18

閉包前端函數

2024-07-29 08:28:00

模型AI

2019-07-09 10:43:57

JavaScriptWeb前端

2020-12-01 17:46:24

FossilGit

2022-03-02 10:53:22

Postman工具開發

2019-12-23 11:03:07

抽象MOVJava

2019-01-02 11:22:27

HTTPFTPSMTP
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久丝袜视频 | 国产精品福利久久久 | 亚洲视频在线免费观看 | 91网站在线观看视频 | 欧美日韩在线观看视频网站 | 不卡一区二区三区四区 | 日韩伦理一区二区 | 久久久精品一区二区三区 | 日韩午夜在线观看 | 婷婷久久综合 | 亚洲精品乱码久久久久久黑人 | 久久国产欧美日韩精品 | 亚洲第一天堂无码专区 | 国产精品一区二区久久久久 | 国产精品美女久久久久 | 欧美精品在线一区二区三区 | 超碰在线久 | 天堂中文av | 成人一级黄色毛片 | 香蕉一区二区 | 91精品国产91久久久久久最新 | 中文字幕在线一区二区三区 | 91精品国产欧美一区二区成人 | 国产精品99久久久久久动医院 | 欧美三级在线 | 精品国产精品 | 精品一区二区三区在线观看国产 | 性一交一乱一伦视频免费观看 | 国产98在线 | 免费, | 久久美国 | 国产精品久久久久久久久久了 | 日韩精品在线一区 | 亚洲视频中文字幕 | 久久成人人人人精品欧 | 国产伦精品一区二区三毛 | 欧美在线二区 | 亚洲二区视频 | 韩日在线观看视频 | 日韩高清一区 | 天天天堂 | 亚洲精品视频播放 |