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