JavaScript中函數(shù)聲明優(yōu)先于變量聲明的實例分析
更新時間:2012年03月01日 22:21:21 作者:
同一個標示符,先后用var和function聲明它。最后它是什么呢
復制代碼 代碼如下:
var a; // 聲明一個變量,標識符為a
function a() { // 聲明一個函數(shù),標示符也為a
}
alert(typeof a);
顯示的是“function”,即function的優(yōu)先級高于var。
有人覺得這是代碼順序執(zhí)行的原因,即a被后執(zhí)行的funcion覆蓋了。好,將它們調(diào)換下。
復制代碼 代碼如下:
function a() {
}
var a;
alert(typeof a);
結(jié)果仍然顯示的是“function”而非“undefined”。即函數(shù)聲明優(yōu)先于變量聲明。
我們把代碼稍作修改,聲明a時同時賦值。
復制代碼 代碼如下:
function a() {
}
var a = 1; // 注意此處
alert(typeof a);
這時顯示的是“number”卻不是“function”了,這相當于
復制代碼 代碼如下:
function a() {
}
var a;
a = 1; // 注意此處
alert(typeof a);
即把“var a = 1”拆分為兩步。 a被重新賦值了,自然是最后的那個值。
相關文章
微信小程序?qū)崿F(xiàn)tabbar凹凸圓選中動畫效果實例
小程序日益增多的情況下,UI風格顯得越來越重要,下面這篇文章主要給大家介紹了關于微信小程序?qū)崿F(xiàn)tabbar凹凸圓選中動畫效果的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2022-09-09無循環(huán) JavaScript(map、reduce、filter和find)
本文由淺入深地介紹了map、reduce、filter和find函數(shù),如何一步一步把循環(huán)從代碼中抽離掉2017-04-04