JavaScript的變量聲明提升問題淺析(Hoisting)
一、變量聲明提升
hoisting 英[‘hɔɪstɪŋ] 美[‘hɔɪstɪŋ]
n. 起重,提升
v. 把…吊起,升起( hoist的現(xiàn)在分詞 )
先來看一個(gè)栗子
var cc = 'hello'; function foo(){ console.log(cc); var cc = 'world'; console.log(cc); } foo(); console.log(cc);
這里將會(huì)輸出 undefined
、'world'
、'hello'
此處主要有兩個(gè)知識(shí)點(diǎn):
1、作用域
2、變量聲明提升
JavaScript是一門解釋性語言,當(dāng)代碼在解釋器(如Chrome的V8引擎)環(huán)境中執(zhí)行時(shí),會(huì)有一個(gè)預(yù)解析的過程,此時(shí)會(huì)將變量聲明和函數(shù)聲明提升至當(dāng)前作用域的最前方,這個(gè)行為被稱為聲明提升(Hoisting)
再來看上面的例子,此代碼有兩層作用域,全局作用域和函數(shù)foo
作用域,而foo
中的變量聲明在預(yù)解析的過程中會(huì)被提升至函數(shù)作用域的前方,于是代碼就會(huì)變成這樣:
var cc = 'hello'; function foo(){ var cc; console.log(cc); cc = 'world'; console.log(cc); } foo(); console.log(cc);
當(dāng)執(zhí)行到第一個(gè)log時(shí),變量cc只是進(jìn)行了聲明,并未賦值,所以打印出的是undefined
二、 函數(shù)聲明提升
函數(shù)的聲明有兩種方式:函數(shù)聲明和函數(shù)表達(dá)式
// 函數(shù)聲明 function foo(a, b) { return a + b; } // 函數(shù)表達(dá)式 var foo = function(a, b) { return a + b; }
解析器在向執(zhí)行環(huán)境中加載數(shù)據(jù)時(shí),對(duì)函數(shù)聲明和函數(shù)表達(dá)式并非一視同仁。解析器會(huì)率先讀取函數(shù)聲明,并使其在執(zhí)行任何代碼之前可用(可以訪問);至于函數(shù)表達(dá)式,則必須等到解析器執(zhí)行到它所在的代碼行,才會(huì)真正被解釋執(zhí)行。
當(dāng)然,也可以函數(shù)聲明和函數(shù)表達(dá)式同時(shí)使用,如var a = function b(){}
,其結(jié)果是只具有函數(shù)表達(dá)式的作用,b會(huì)被自動(dòng)忽略,所以只會(huì)發(fā)生變量提升效果。
總結(jié)
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流。
相關(guān)文章
Js參數(shù)值中含有單引號(hào)或雙引號(hào)問題的解決方法
本文是對(duì)Js參數(shù)值中含有單引號(hào)或雙引號(hào)問題的解決方法進(jìn)行了總結(jié)介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助2013-11-11Bootstrap table學(xué)習(xí)筆記(2) 前后端分頁模糊查詢
這篇文章主要為大家分享了Bootstrap table學(xué)習(xí)筆記,前后端分頁模糊查詢,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-05-05js數(shù)組刪除問題(splice和delete的用法)
這篇文章主要介紹了js數(shù)組刪除問題(splice和delete的用法),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02mui開發(fā)中獲取單選按鈕、復(fù)選框的值(實(shí)例講解)
下面小編就為大家?guī)硪黄猰ui開發(fā)中獲取單選按鈕、復(fù)選框的值(實(shí)例講解)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-07-07