javascript - console.log(typeof(named));的位置不同,第二個(gè)為什么會(huì)顯示undefined ?
問(wèn)題描述
為什么位于全局作用域中的 console.log(typeof(named)); 訪(fǎng)問(wèn)不了函數(shù)表達(dá)式的名字?函數(shù)聲明后,名字不是暴露在全局作用域中了嗎,求解
問(wèn)題解答
回答1:函數(shù)表達(dá)式與函數(shù)聲明有幾點(diǎn)重要區(qū)別:
1, 函數(shù)聲明會(huì)定義一個(gè)同名的變量,這個(gè)變量就是函數(shù)本身。函數(shù)表達(dá)式只是把定義的函數(shù)當(dāng)成一個(gè)值,即使在function后加一個(gè)名字,它也不會(huì)把這個(gè)名字定義成變量,這個(gè)函數(shù)表達(dá)式是一個(gè)值,可以賦給其他變量。
function a(){} // 函數(shù)聲明,同時(shí)在外部作用域定義了可以使用的變量avar b = function(){} //函數(shù)表達(dá)式,匿名函數(shù)是一個(gè)值,賦值給了變量bvar d = function c(){} //函數(shù)表達(dá)式,函數(shù)本身是一個(gè)值,沒(méi)有在外部作用域定義變量c,但賦值給了變量d。
2, 可以看到函數(shù)表達(dá)式里可以寫(xiě)function()也可以寫(xiě)function c(),既然后者也不會(huì)在外部作用域定義變量c,那么它們的區(qū)別在哪里,簡(jiǎn)單說(shuō)有兩點(diǎn):
var d = function c(){}里的d.name是存在的,值為字符串c,而var b = function(){}里的b.name是個(gè)undefined。
在function c(){}的函數(shù)體內(nèi)部作用域,變量c是存在的,并且就是函數(shù)本身,和外部作用域的變量d等價(jià),而匿名函數(shù)function(){}內(nèi)部只能用變量b來(lái)引用。
所以這就解釋了你在function named(){}函數(shù)體內(nèi)訪(fǎng)問(wèn)到了named這個(gè)變量,而在外部作用域得到的是個(gè)未定義變量的問(wèn)題。
