命名函数表达式不会预先提升

Posted 张宝的博客

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了命名函数表达式不会预先提升相关的知识,希望对你有一定的参考价值。

使用javascript时,当你这样调用函数是没有问题的

1 func1();
2 function func1() {
3     console.log(‘func1‘);
4 }
5 func1();

 

如果你这样

1 func2(); // Uncaught TypeError: func2 is not a function
2 
3 var func2 = function () {
4     console.log(‘func2‘);
5 } 
6 
7 func2();

在第一行就会得到func2 is not a function的错误。因为上面的代码和下面是等价的

1 var func2;
2 
3 func2(); // Uncaught TypeError: func2 is not a function
4 
5 func2 = function () {
6     console.log(‘func2‘);
7 } 
8 
9 func2();

func2只是声明了,但并没有被赋值,也就是说,第3行调用语句出现时,func2的值还是undefined!因此,浏览器报错说“func2不是一个函数”。

 

总结:不同于直接声明函数的形式,函数表达式不会预先提升。

 

(完)

 

以上是关于命名函数表达式不会预先提升的主要内容,如果未能解决你的问题,请参考以下文章

作用域

js立即执行函数

命名函数

JavaScript 变量声明提升

变量提示,函数提升

JavaScript之变量提升