亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

JS變量提升及函數提升實例解析

瀏覽:96日期:2024-04-22 11:39:02

1在js中只有兩種作用域

a:全局作用域

b:函數作用域

在ES6之前,js是沒有塊級作用域。

首先來解釋一下什么是沒有塊級作用域?

JS變量提升及函數提升實例解析

所以此時 是可以打印輸出變量a的值。

2:什么是變量提升?

在我們的js中,代碼的執行時分兩步走的,1、預解析 2、一步一步執行

在預解析階段:首先會在全局作用域內,js解析器會找所有的 var 、function 、參數,并提前到當前作用域的最頂上去(變量的賦值操作不會提前,還在原來的地方),此時并沒有執行代碼。

然后再開始一行一行執行代碼。遇到了函數調用,于是進入到函數作用域內,又開始分兩步驟走,1、預解析 2、一步一步執行。以此類推。

那么變量提升就是變量聲明會被提升到作用域的最頂上去,也就是該變量不管是在作用域的哪個地方聲明的,都會提升到作作用域的最頂上去。

即變量可以在聲明之前使用,值為undefined。

JS變量提升及函數提升實例解析

那么上面這種寫法其實等價于下面這種寫法:

JS變量提升及函數提升實例解析

看幾個例子:

JS變量提升及函數提升實例解析

把上面的例子稍作改動:

結果就會大不一樣,

JS變量提升及函數提升實例解析

再看一個例子:

JS變量提升及函數提升實例解析

3:什么是函數提升?

JS變量提升及函數提升實例解析

輸出的結果是:

JS變量提升及函數提升實例解析

注意:函數聲明式,會將函數的聲明和定義一起提升到作用域的最頂上去。

如果是這種寫法:函數表達式聲明的函數

JS變量提升及函數提升實例解析

例子:

JS變量提升及函數提升實例解析

輸出的結果是:

JS變量提升及函數提升實例解析

最后的總結:

1:所有的聲明都會提升到作用域的最頂上去。

2:同一個變量只會聲明一次,其他的會被忽略掉。

3:函數聲明的優先級高于變量申明的優先級,并且函數聲明和函數定義的部分一起被提升。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 国产精品二区高清在线 | 欧美 另类 精品一区视频 | 国产成人亚洲精品 | 九九久久久久午夜精选 | 成人免费观看网欧美片 | 视频亚洲一区 | 国产一级做a爱免费观看 | 亚洲免费视频一区 | 人妖欧美一区二区三区四区 | 中文字幕在线观看日韩 | 纯欧美一级毛片_免费 | 欧美在线观看不卡 | 亚洲视频欧美视频 | 在线成人| 日韩亚洲精品不卡在线 | 久久在线播放 | 久久久久久久久久久久福利 | 5x性区m免费毛片视频看看 | 亚洲第一免费网站 | 亚洲一区二区视频 | 中文字幕中文字幕在线 | 韩国一级做a爰片性色毛片 韩国一区在线 | 美国一级做a一级视频 | 欧美激情一区二区三区高清视频 | 美女张开腿给男人桶 | 久色一区 | 久久99亚洲精品久久久久 | 美女扒开腿让男生桶爽网站 | 看欧美的一级毛片 | 亚洲国产精品一区二区三区 | 亚洲免费观看 | 日本红怡院亚洲红怡院最新 | 亚洲福利精品一区二区三区 | 在线精品一区二区三区 | 一区二区三区四区在线播放 | 色综合久久久久久888 | 精品视频一区二区三区四区 | 中文字幕一区二区在线观看 | 久久频这里精品99香蕉久网址 | 亚洲国产综合久久精品 | 日本韩国中文字幕 |