JS中函数声明与函数表达式的异同
相同点
注:函数声明和函数表达式的相同点包括但不限于以下几点
-
函数是一个值,所以和其他值一样,函数也可以进行被输出、被赋值、作为参数传给其他函数等相关操作,不管函数是以什么方式被定义的,当然和其他值的输出还是有些区别的。
我们先来输出这个值:
function nameAlert(name){ alert('博主的名字是:' + name + ' 。'); } alert(nameAlert); 注意输出的结果并不是1,而是这个函数的整个源代码,即输出结果为:function nameAlert(name){ alert('博主的名字是:' + name + ' 。'); }
-
作为参数传给其他函数。
function nameAlert(name){ alert('博主的名字是:' + name + ' 。'); }var anotherNameAlert=nameAlert; anotherNameAlert('myvin');
该例子中将函数
nameAlert
作为参数传给了anotherNameAlert
,然后anotherNameAlert
也指向了该函数。这里就涉及到了函数的传递,函数的传递是传引用,就是说函数存在内存中的某个位置,
nameAlert
和anotherNameAlert
是都是函数的一个引用,把函数名nameAlert
赋值给anotherNameAlert
的时候,它们引用的都是同一个函数。所以
anotherNameAlert
的输出结果为:博主的名字是:myvin 。
当然函数还有其他特点,在此不再介绍,感兴趣的可以自己总结下。
不同点
注:函数声明和函数表达式的不同点包括但不限于以下几点
相对函数声明和函数表达式之间的相同点,它们的不同点更应该值得我们关注。下面我结合自己的理解聊聊。
-
函数声明必须有标识符,也就是常说的函数名;函数表达式可以省略函数名。
关于它们的定义的不同小伙伴们应该都知道,我们简单重复一遍。
如下:
函数声明(要带标识符)
function functionName(arg1, arg2, ...){ <!-- function body -->}
函数表达式
-
省略标识符:
var variable=function(arg1, arg2, ...){ <!-- function body -->}
-
带有标识符:
var variable=function functionName(arg1, arg2, ...){ <!-- function body -->}
事实上,js的解析器对函数声明与函数表达式并不是一视同仁地对待的。对于函数声明,js解析器会优先读取,确保在所有代码执行之前声明已经被解析,而函数表达式,如同定义其它基本类型的变量一样,只在执行到某一句时也会对其进行解析,所以在实际中,它们还是会有差异的,具体表现在,当使用函数声明的形式来定义函数时,可将调用语句写在函数声明之前,而后者,这样做的话会报错。
参考链接:http://www.cnblogs.com/myvin/p/4649789.html
http://blog.****.net/one_and_only4711/article/details/6361131