javascript - 看到函數(shù)聲明這塊有個(gè)函數(shù)不是很理解
問(wèn)題描述
這是js高程上面的一個(gè)例子看到函數(shù)聲明有一個(gè)代碼
if(condition){ function sayHi(){alert(’hi’) }}else{ function sayHi(){alert(’Yo’) }}
說(shuō)是這段代碼無(wú)效語(yǔ)法,大多數(shù)瀏覽器會(huì)返回第二個(gè)聲明,firefox會(huì)返回第一個(gè)聲明,這是為什么?如果改成函數(shù)表達(dá)式形式的就可以了,這又是為什么?
var sayHi;if(condition){ sayHi=function(){alert(’Hi’) }}else{ sayHi=function(){alert(’Yo!’) }}
問(wèn)題解答
回答1:因?yàn)榈谝粋€(gè)是函數(shù)聲明, 但是一般不會(huì)放在if-else中聲明函數(shù)
第二個(gè)是把匿名函數(shù)賦值給變量 ,不存在提升之類的
回答2:直接寫function xxx(){} 會(huì)導(dǎo)致聲明提前,如果有兩個(gè)同名的這樣的函數(shù),相當(dāng)于在頂部執(zhí)行了兩次var xxx,所以無(wú)效
回答3:和什么聲明前置沒有關(guān)系,高程第三部那時(shí)候JavaScript規(guī)范還都是ES5,瀏覽器還沒有實(shí)現(xiàn)塊級(jí)作用域(ES2016+),作用域級(jí)別只是函數(shù)級(jí)別的。所以你寫的
if(condition){ function sayHi(){alert(’hi’) }}else{ function sayHi(){alert(’Yo’) }}
和寫的
function sayHi(){ alert(’hi’)}function sayHi(){ alert(’Yo’)}
沒有本質(zhì)區(qū)別
回答4:js是有聲明提前的!!!function會(huì)在聲明時(shí)直接提到作用域頂端。if中不存在作用域,所以兩個(gè)function是一個(gè)作用域,第二個(gè)會(huì)替掉第一個(gè)。! 而你第二段代碼,先聲明了變量sayhi,在if判斷后才對(duì)sayhi進(jìn)行賦值,
相關(guān)文章:
1. mysql - AttributeError: ’module’ object has no attribute ’MatchType’2. github - 利用Python 自動(dòng)化部署問(wèn)題3. 求大神幫我看看是哪里寫錯(cuò)了 感謝細(xì)心解答4. npm鏡像站全新上線5. javascript - 圖片能在網(wǎng)站顯示,但控制臺(tái)仍舊報(bào)錯(cuò)403 (Forbidden)6. python - from ..xxxx import xxxx到底是什么意思呢?7. php自學(xué)從哪里開始?8. MySQL客戶端吃掉了SQL注解?9. phpstady在win10上運(yùn)行10. 數(shù)據(jù)庫(kù) - MySQL 單表500W+數(shù)據(jù),查詢超時(shí),如何優(yōu)化呢?
