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. css3 讓圖片變成灰色(filter),但針對IE11瀏覽器無效2. 前端 - 集思廣益,如何用CSS實現數字上面有一個點3. html5 - 前端面試碰到了一個緩存數據的問題,來論壇上請教一下4. macos - 無法source activate python275. 我在導入模板資源時遇到無法顯示的問題,請老師解答下6. css - 移動端 盒子內加overflow-y:scroll后 字體會變大7. PHPExcel表格導入數據庫怎么導入8. java - 同步/異步與阻塞/非阻塞之間的差異具體是什么?9. 運行python程序時出現“應用程序發生異常”的內存錯誤?10. java - butterknife怎么綁定多個view

網公網安備