javascript - console.log(typeof(named));的位置不同,第二个为什么会显示undefined ?
本文介绍了javascript - console.log(typeof(named));的位置不同,第二个为什么会显示undefined ?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
问 题
为什么位于全局作用域中的 console.log(typeof(named)); 访问不了函数表达式的名字?
函数声明后,名字不是暴露在全局作用域中了吗,求解
解决方案
函数表达式与函数声明有几点重要区别:
1, 函数声明会定义一个同名的变量,这个变量就是函数本身。函数表达式只是把定义的函数当成一个值,即使在function
后加一个名字,它也不会把这个名字定义成变量,这个函数表达式是一个值,可以赋给其他变量。
function a(){} // 函数声明,同时在外部作用域定义了可以使用的变量a
var b = function(){} //函数表达式,匿名函数是一个值,赋值给了变量b
var d = function c(){} //函数表达式,函数本身是一个值,没有在外部作用域定义变量c,但赋值给了变量d。
2, 可以看到函数表达式里可以写function()
也可以写function c()
,既然后者也不会在外部作用域定义变量c,那么它们的区别在哪里,简单说有两点:
var d = function c(){}
里的d.name是存在的,值为字符串c,而var b = function(){}
里的b.name是个undefined。在
function c(){}
的函数体内部作用域,变量c是存在的,并且就是函数本身,和外部作用域的变量d等价,而匿名函数function(){}
内部只能用变量b来引用。
所以这就解释了你在function named(){}
函数体内访问到了named这个变量,而在外部作用域得到的是个未定义变量的问题。
这篇关于javascript - console.log(typeof(named));的位置不同,第二个为什么会显示undefined ?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文