日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

js变量提升_一道JS变量提升题

發布時間:2023/12/10 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 js变量提升_一道JS变量提升题 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

var a = 0;if(true){a = 1;function a(){};a = 21;console.log(a);}console.log(a);// 21 1

當前上下文代碼執行之前,會將帶var/function的進行聲明/定義。

當遇到“{}”時,新版瀏覽器和老版瀏覽器的處理不一致。

老版瀏覽器(IE10以下)忽略“{}”的影響,繼續聲明/定義,不存在塊級作用域

新版瀏覽器中“{}”里的function只聲明不定義,“{}”若出現funciton/let/const關鍵字,會創建一個塊級上下文


本題在全局變量提升階段會聲明一個變量a,在塊級作用域內的function a同樣會聲明,但是不定義。 代碼繼續執行

var a = 0;

在全局下給a賦值0。

if(true){a = 1;function a(){};a = 21;console.log(a);}

代碼執行到條件判斷時,創建一個塊級作用域,在塊級作用域內進行變量提升,聲明并且定義funciton a。

a = 1;

塊級作用域內給a賦值為1。

繼續執行到函數定義的地方為了兼容ES3和ES6瀏覽器會做這樣一步操作:

把代碼之前所有對a的操作映射到全局

于時之前對塊級作用域內變量a賦值為1的操作也會映射到全局的變量a,所以全局的a變成了1。所以最后控制臺打印的是結果是21,和1,因為全局的a映射了。

總結

以上是生活随笔為你收集整理的js变量提升_一道JS变量提升题的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。