javascript - 看到函數聲明這塊有個函數不是很理解
問題描述
這是js高程上面的一個例子看到函數聲明有一個代碼
if(condition){ function sayHi(){alert(’hi’) }}else{ function sayHi(){alert(’Yo’) }}
說是這段代碼無效語法,大多數瀏覽器會返回第二個聲明,firefox會返回第一個聲明,這是為什么?如果改成函數表達式形式的就可以了,這又是為什么?
var sayHi;if(condition){ sayHi=function(){alert(’Hi’) }}else{ sayHi=function(){alert(’Yo!’) }}
問題解答
回答1:因為第一個是函數聲明, 但是一般不會放在if-else中聲明函數
第二個是把匿名函數賦值給變量 ,不存在提升之類的
回答2:直接寫function xxx(){} 會導致聲明提前,如果有兩個同名的這樣的函數,相當于在頂部執行了兩次var xxx,所以無效
回答3:和什么聲明前置沒有關系,高程第三部那時候JavaScript規范還都是ES5,瀏覽器還沒有實現塊級作用域(ES2016+),作用域級別只是函數級別的。所以你寫的
if(condition){ function sayHi(){alert(’hi’) }}else{ function sayHi(){alert(’Yo’) }}
和寫的
function sayHi(){ alert(’hi’)}function sayHi(){ alert(’Yo’)}
沒有本質區別
回答4:js是有聲明提前的!!!function會在聲明時直接提到作用域頂端。if中不存在作用域,所以兩個function是一個作用域,第二個會替掉第一個。! 而你第二段代碼,先聲明了變量sayhi,在if判斷后才對sayhi進行賦值,
相關文章:
1. javascript - 大家都在用vue來做單頁項目,那vue是否可以在傳統多頁項目上?2. Eclipse / Java-導入java。(namespace)。*是否有害?3. mysql - SQL語句可以提供“查詢表,并至第100條結果為止”嗎?4. java中返回一個對象,和輸出對像的值,意義在哪兒5. python - xpath提取網頁路徑沒問題,但是缺失內容?6. node.js - JavaScript的一個不能理解的地方7. javascript - js一個call和apply的問題?8. android - 安卓做前端,PHP做后臺服務器 有什么需要注意的?9. javascript - 給某個類添加一個偽類,這個類有click事件,現在我點擊偽類也觸發了click事件10. docker不顯示端口映射呢?
