javascript - 看到函數(shù)聲明這塊有個函數(shù)不是很理解
問題描述
這是js高程上面的一個例子看到函數(shù)聲明有一個代碼
if(condition){ function sayHi(){alert(’hi’) }}else{ function sayHi(){alert(’Yo’) }}
說是這段代碼無效語法,大多數(shù)瀏覽器會返回第二個聲明,firefox會返回第一個聲明,這是為什么?如果改成函數(shù)表達(dá)式形式的就可以了,這又是為什么?
var sayHi;if(condition){ sayHi=function(){alert(’Hi’) }}else{ sayHi=function(){alert(’Yo!’) }}
問題解答
回答1:因為第一個是函數(shù)聲明, 但是一般不會放在if-else中聲明函數(shù)
第二個是把匿名函數(shù)賦值給變量 ,不存在提升之類的
回答2:直接寫function xxx(){} 會導(dǎo)致聲明提前,如果有兩個同名的這樣的函數(shù),相當(dāng)于在頂部執(zhí)行了兩次var xxx,所以無效
回答3:和什么聲明前置沒有關(guān)系,高程第三部那時候JavaScript規(guī)范還都是ES5,瀏覽器還沒有實現(xiàn)塊級作用域(ES2016+),作用域級別只是函數(shù)級別的。所以你寫的
if(condition){ function sayHi(){alert(’hi’) }}else{ function sayHi(){alert(’Yo’) }}
和寫的
function sayHi(){ alert(’hi’)}function sayHi(){ alert(’Yo’)}
沒有本質(zhì)區(qū)別
回答4:js是有聲明提前的!!!function會在聲明時直接提到作用域頂端。if中不存在作用域,所以兩個function是一個作用域,第二個會替掉第一個。! 而你第二段代碼,先聲明了變量sayhi,在if判斷后才對sayhi進(jìn)行賦值,
相關(guān)文章:
1. mysql優(yōu)化 - 關(guān)于mysql分區(qū)2. javascript - 循環(huán)嵌套多個promise應(yīng)該如何實現(xiàn)?3. 前端 - IE9 css兼容問題4. css - 移動端字體設(shè)置問題5. html5 - 如何實現(xiàn)帶陰影的不規(guī)則容器?6. vue.js - vue 打包后 nginx 服務(wù)端API請求跨域問題無法解決。7. javascript - ionic2 input autofocus 電腦成功,iOS手機鍵盤不彈出8. node.js - 在vuejs-templates/webpack中dev-server.js里為什么要exports readyPromise?9. css3 - rem布局下,用戶瀏覽器的最小字號是12px怎么辦?10. objective-c - iOS開發(fā)支付寶和微信支付完成為什么跳轉(zhuǎn)到了之前開發(fā)的一個app?
