web面試之JS預(yù)解析與變量提升區(qū)別
什么是預(yù)解析?
概念:
JS代碼在在代碼從上往下執(zhí)行前,瀏覽器會(huì)先把所有變量聲明解析一遍, 這個(gè)階段叫預(yù)解析。
詳講
尋找作用域中的var 和function聲明(匿名函數(shù)沒有function聲明,所以不會(huì)提升),然后對(duì)其進(jìn)行事先聲明, 并把賦值操作留在原地,再從上到下執(zhí)行代碼。這就是一個(gè)預(yù)解析的過程。
變量和函數(shù)預(yù)解析的區(qū)別
在預(yù)解析時(shí),會(huì)把所有用 var
聲明的變量, 和 function
聲明的函數(shù),提升到所在的作用域最頂端
var
聲明的變量, 在預(yù)解析的時(shí), 只是提前了聲明, 賦值語句依然留在原地;
function
聲明的函數(shù), 在預(yù)解析的時(shí), 會(huì)提前聲明并同時(shí)定義, 函數(shù)執(zhí)行的時(shí)候,函數(shù)內(nèi)部才會(huì)進(jìn)行預(yù)解析。
注意: 匿名函數(shù)沒有function聲明,所以不會(huì)提升
重復(fù)聲明var變量
var重復(fù)聲明時(shí):若已經(jīng)存在,編譯器會(huì)忽略 var
繼續(xù)向下編譯;
若不存在,則順著作用域鏈向上查找,
若沒有找到,會(huì)在本作用域聲明該變量
變量提升和函數(shù)提升優(yōu)先級(jí)
總結(jié):
函數(shù)提升優(yōu)先級(jí)高于變量提升,且不會(huì)被同名變量聲明時(shí)覆蓋,但是會(huì)被變量賦值后覆蓋
下面內(nèi)容轉(zhuǎn)載自:
https://blog.csdn.net/caoyafeicyf/article/details/53172532
函數(shù)優(yōu)先級(jí)大于變量優(yōu)先級(jí)的深入探究
瀏覽器的預(yù)解析過程
先由一道小題進(jìn)入本文
var foo; function foo(){} console.log(foo);
結(jié)果是函數(shù)體function foo(){}
接著下面一道題:
function foo(){}var foo;console.log(foo);
結(jié)果也是函數(shù)體
function foo(){}
所有就有很多人說,函數(shù)聲明的優(yōu)先級(jí)大于變量聲明的優(yōu)先級(jí)。
那么,為什么呢?這就要從瀏覽器的預(yù)解析說起了。
預(yù)解析流程
搜尋預(yù)解析關(guān)鍵字
尋找var關(guān)鍵字
尋找function關(guān)鍵字
執(zhí)行預(yù)解析
先應(yīng)用var關(guān)鍵字聲明的標(biāo)識(shí)符,使這些標(biāo)識(shí)符有定義
標(biāo)識(shí)符有定以后,使用這項(xiàng)標(biāo)識(shí)符就不會(huì)報(bào)錯(cuò)了但因?yàn)闆]有賦值,因此其值為undefined
至此標(biāo)識(shí)符中保存了函數(shù)的引用
幾個(gè)需要注意的細(xì)節(jié)
- var 關(guān)鍵字對(duì)同一個(gè)標(biāo)識(shí)符重復(fù)使用時(shí),除第一次有效外,其他均做忽略處理。
- 預(yù)解析時(shí)先處理變量聲明,再處理函數(shù)聲明不
- 要糾結(jié)誰的優(yōu)先級(jí)高,這些只是表面現(xiàn)象
- 懂得了預(yù)解析流程,一切都是浮云
看了預(yù)解析原理以后,下面咱們回到本文開頭的兩題,分析下預(yù)解析的過程,詳細(xì)的了解為什么函數(shù)的優(yōu)先級(jí)高于變量的優(yōu)先級(jí)。follow me
先看第一個(gè)
var foo; function foo(){} console.log(foo);
預(yù)解析過程為:
var foo;<----變量聲明的var var foo;<----函數(shù)聲明抽出的var foo=function (){}<----函數(shù)聲明抽出的賦值 console.log(foo);
再來看第二個(gè)
function foo(){} var foo; console.log(foo);
預(yù)解析過程為:
var foo;<----變量聲明的var var foo;<----函數(shù)聲明抽出的var foo=function (){}<----函數(shù)聲明抽出的賦值 console.log(foo)
比較這兩個(gè),你發(fā)現(xiàn)了什么?原來他們的預(yù)解析過程一樣啊,這也就是為什么函數(shù)優(yōu)先級(jí)高于變量的原因了。
如果你理解了上面的內(nèi)容,那么下面再出一個(gè)題:
var a=1; function a(){} console.log(a);
這個(gè)瀏覽器是如何解析的呢?下面來跟著我的思路一起走:
1. 解析器首先搜尋var 關(guān)鍵字,結(jié)果第一行就發(fā)現(xiàn)了,把它提取到開頭。
2. 解析器搜尋function關(guān)鍵字,第二行發(fā)現(xiàn)了,首先分離var+函數(shù)名,此時(shí)發(fā)現(xiàn)和第一步的一樣,不做處理,然后開始分離函數(shù)的賦值,也就是a=function (){}
,此時(shí)a為函數(shù)體。
3. 解析器接著處理變量的賦值,a=1
,上一步的函數(shù)體被覆蓋掉,此時(shí)a=1。
4. 最后處理console.log(a)
,自然而然的結(jié)果為1。
下面是解析器處理的代碼過程:
var a;<----變量聲明的var var a;<----函數(shù)聲明抽出的var a=function (){}<----函數(shù)聲明抽出的賦值 a=1; console.log(a);
以上就是web面試之JS預(yù)解析與變量提升區(qū)別的詳細(xì)內(nèi)容,更多關(guān)于JS預(yù)解析與變量提升的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
JavaScript fontsize方法入門實(shí)例(按照指定的尺寸來顯示字符串)
這篇文章主要介紹了JavaScript fontsize方法入門實(shí)例,fontsize方法用于按照指定的尺寸來顯示字符串,需要的朋友可以參考下2014-10-10淺談JavaScript函數(shù)的四種存在形態(tài)
下面小編就為大家?guī)硪黄獪\談JavaScript函數(shù)的四種存在形態(tài)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06深入理解JavaScript系列(21):S.O.L.I.D五大原則之接口隔離原則ISP詳解
這篇文章主要介紹了深入理解JavaScript系列(21):S.O.L.I.D五大原則之接口隔離原則ISP詳解,本文講解了JavaScript接口、ISP與JavaScript、墮落的實(shí)現(xiàn)、靜態(tài)耦合、語義耦合、可擴(kuò)展性等內(nèi)容,需要的朋友可以參考下2015-03-03javascript基礎(chǔ)語法——全面理解變量和標(biāo)識(shí)符
下面小編就為大家?guī)硪黄猨avascript基礎(chǔ)語法——全面理解變量和標(biāo)識(shí)符。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考,一起跟隨小編過來看看吧2016-06-06JavaScript中匿名、命名函數(shù)的性能測(cè)試
這篇文章主要介紹了JavaScript中匿名、命名函數(shù)的性能測(cè)試,簡單來講匿名即沒有名字的函數(shù),它和命名函數(shù)相比性能如何呢,本文即是對(duì)它們性能的測(cè)試,需要的朋友可以參考下2014-09-09實(shí)現(xiàn)JavaScript的組成----BOM和DOM詳解
下面小編就為大家?guī)硪黄獙?shí)現(xiàn)JavaScript的組成----BOM和DOM詳解。小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考,一起跟隨小編過來看看吧2016-05-05ajax提交表單實(shí)現(xiàn)網(wǎng)頁無刷新注冊(cè)示例
這篇文章主要介紹了ajax提交表單實(shí)現(xiàn)網(wǎng)頁無刷新注冊(cè)示例,需要的朋友可以參考下2014-05-05