千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > web前端教程之JavaScript的作用域

web前端教程之JavaScript的作用域

來源:千鋒教育
發布人:小千
時間: 2021-01-19 09:07:00 1611018420

      作為一個前端工程師,你必須對JavaScript的作用域不陌生,傳統常見的有函數級作用域,還有全局作用域,ES6 let const 的塊級作用域,其實還有一個你不知道的塊級作用域,今天小千就來給大家介紹一下。

      我們先來看看下面這個段代碼,請思考一下結果是什么。

1

      想必你心中已經有了結果,答案是 3  2

      你答對了嗎?答案結果是否有些意外呢?

      好了,我們來看看為什么會出現這個答案?首先我們需要先了解以下基本知識。

      聲明提前

      聲明提前指的是JS引擎在執行之前對代碼進行的預解析(為了提高執行效率) 具體的來說就是使用(var)聲明變量和(function)聲明的函數正預編譯階段將其提升到了作用域的頂部

      全局變量聲明

2

      函數作用域變量聲明

3

      函數聲明

4

      函數表達式聲明

5

      函數塊級作用域

      通過下面代碼我們可以知道 變量的聲明是沒有塊級作用域的,if語句塊中聲明的變量foo會提升到全局作用域并初始化值為undefined

6

      我們再看看函數的情況

7

      上面這個例子告訴我們 函數foo提升到了if語句塊的頂部,但是沒有提升到全局作用域的頂部。但全局作用域中存有一個名為foo的變量 在代碼執行后同步成了函數foo

      同步?為什么會有同步?我們來看看觀察上帝視角的神器 ———— 斷點調試。我這邊監聽了 foo 變量和 window.foo 大家請注意一下它的變化。同時我們也關注一下 Scope 作用域

      我們看到Scope中只有全局作用域 foo和window.foo的只都是undefined

8

      代碼執行到if語句塊中 我們再Scope中又發現了一個新的塊級作用域 當前塊級作用域foo的值被賦值為一個函數(函數提升) 而全局作用域中的foo依舊是undefined

9

      代碼繼續往后執行 執行函數的賦值 block作用域依然存在 我把幾個變量的值使用箭頭進行了對應

10

      神奇的地方來了 在函數執行賦值后 塊級作用域消失 而全局變量的foo同步成了剛才塊級作用域的foo

11

      回歸原題

      我們對foo變量進行隔行輸出 看看結果

12

      結合上面斷點測試的結果大家可以發現,函數在代碼塊中聲明會提前到塊級作用域頂部,預編譯結束后開始執行代碼 在執行階段任然會執行函數的賦值操作,其實是函數賦值的第二次執行(第一次在預編譯階段) 第二次的賦值執行的意義是確認當前 函數/全局 作用域能準確的檢索到函數 所以講函數同步到了 當前的函數或全局作用域中。

      好了本次解析就到這里,還有不明白的小伙伴可以copy代碼去進行斷點測試,相信很快你能理解其中奧秘。 

      學習web前端,可以參考千鋒web前端培訓班提供的web前端學習路線,該學習路線對從零基礎小白到web前端初級開發工程師,web前端高級開發工程師,后面的web前端大神級開發工程師都有一個明確清晰的指導,根據千鋒web前端培訓機構提供的web前端學習路線圖可以讓你對學習web前端開發需要掌握的知識有個清晰的了解,并快速入門web前端開發。想要獲取前端完整學習路線和免費的學習資料可以添加我們的web前端技術分享交流qq群:857920838  加群找群管理領取即可,等你來哦~~

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
久久亚洲中文字幕精品一区四,亚洲日本另类欧美一区二区,久久久久久久这里只有免费费精品,高清国产激情视频在线观看
亚洲国产每日更新 | 亚洲欧美国产高清vA在线播放 | 日本一本中文一区在线 | 欧美性爱A免费在线观看 | 在线亚洲欧美日本专区 | 天天影视色香欲一区二区 |