JavaScript中函式宣告優先於變數宣告的例項分析

NO IMAGE

複製程式碼 程式碼如下:
var a; // 宣告一個變數,識別符號為a
function a() { // 宣告一個函式,標示符也為a
}
alert(typeof a);

顯示的是“function”,即function的優先順序高於var。
有人覺得這是程式碼順序執行的原因,即a被後執行的funcion覆蓋了。好,將它們調換下。
複製程式碼 程式碼如下:
function a() {
}
var a;
alert(typeof a);

結果仍然顯示的是“function”而非“undefined”。即函式宣告優先於變數宣告。
我們把程式碼稍作修改,宣告a時同時賦值。
複製程式碼 程式碼如下:
function a() {
}
var a = 1; // 注意此處
alert(typeof a);

這時顯示的是“number”卻不是“function”了,這相當於
複製程式碼 程式碼如下:
function a() {
}
var a;
a = 1; // 注意此處
alert(typeof a);

即把“var a = 1”拆分為兩步。 a被重新賦值了,自然是最後的那個值。

您可能感興趣的文章:

跟我學習javascript的var預解析與函式宣告提升JavaScript中變數提升 Hoistingjavascript中的變數作用域以及變數提升詳細介紹JavaScript中提前宣告變數或函式例子淺談JavaScript中變數和函式宣告的提升