JavaScript 中,定义函数时用 var foo = function () {} 和 function foo() 有什么区别?

先看以下代码:

方法一: 
var foo = function () { 
    alert("aa"); 
} 
方法二: 
function foo () { 
    alert("aa"); 
} 

这两个方法的根本区别:JavaScript 函数和变量声明的“提前”(hoist)行为

简单的说 如果我们使用 匿名函数
var FUNCTION_NAME = function() { /* FUNCTION_BODY */}; 
这种方式, 编译后变量声明FUNCTION_NAME 会“被提前”了,但是他的赋值(也就是FUNCTION_BODY)并不会被提前。
也就是,匿名函数只有在被调用时才被初始化。

如果我们使用
function FUNCTION_NAME () 
{ /* FUNCTION_BODY */}; 
这种方式, 编译后函数声明和他的赋值都会被提前。
也就是说函数声明过程在整个程序执行之前的预处理就完成了,所以只要处于同一个作用域,就可以访问到,即使在定义之前调用它也可以。


网上还有一种理解就是:

方法一:foo在进入函数执行上下文开始执行代码的时候,foo是undefined的,知道执行完var foo = function () { }这句,foo才会得到赋值; 

方法二:在进入函数执行上下文开始执行代码的时候,foo已经是一个function了。


以上就是综合各方面的阐述,将问题的实质讲述清楚!


你可能感兴趣的:(js)