先看以下代码:
方法一:
var foo = function () {
alert("aa");
}
方法二:
function foo () {
alert("aa");
}
这两个方法的根本区别:JavaScript 函数和变量声明的“提前”(hoist)行为
简单的说 如果我们使用 匿名函数
这种方式, 编译后变量声明FUNCTION_NAME 会“被提前”了,但是他的赋值(也就是FUNCTION_BODY)并不会被提前。
也就是,匿名函数只有在被调用时才被初始化。
如果我们使用
这种方式, 编译后函数声明和他的赋值都会被提前。
也就是说函数声明过程在整个程序执行之前的预处理就完成了,所以只要处于同一个作用域,就可以访问到,即使在定义之前调用它也可以。
var FUNCTION_NAME = function() { /* FUNCTION_BODY */};
也就是,匿名函数只有在被调用时才被初始化。
如果我们使用
function FUNCTION_NAME ()
{ /* FUNCTION_BODY */};
也就是说函数声明过程在整个程序执行之前的预处理就完成了,所以只要处于同一个作用域,就可以访问到,即使在定义之前调用它也可以。
网上还有一种理解就是:
方法一:foo在进入函数执行上下文开始执行代码的时候,foo是undefined的,知道执行完var foo = function () { }这句,foo才会得到赋值;
方法二:在进入函数执行上下文开始执行代码的时候,foo已经是一个function了。
以上就是综合各方面的阐述,将问题的实质讲述清楚!