Javascript学习笔记:3种定义函数的方式

①使用函数声明语法定义函数

1 function sum(num1,num2){
2   return num1+num2;  
3 }

②使用函数表达式定义函数

1 var sum=function(num1,num2){
2   return num1+num2;  
3 }

③使用Function构造函数定义函数

1 var sum=new Function('num1','num2','return num1+num2');

三种定义函数的方式,其中第二和第三种从技术角度讲都属于函数表达式的方式,但是不推荐使用第三种即使用Function构造函数的方式,因为这种方式性能低于前两种方式。不管以哪种方式定义函数,函数都是Function类型的实例,而且都与其他引用类型一样拥有属性和方法。这三种定义函数的方式唯一不等价的地方是:第二种和第三种方式定义的函数不存在函数声明提升,第一种方式定义的函数存在函数声明提升(所谓函数声明提升,也就是解析器在向执行环境中加载数据时,会率先读取函数声明,并使其在任何代码之前可以访问),其他方面都是等价的。

1 sum(1,2);//3
2 
3 function sum(num1,num2){
4  return num1+num2;
5 }

使用函数声明语法定义函数的方式存在函数声明提升,所以sum函数可以正常执行。

1 sum(1,2);//TypeError: sum is not a function
2 
3 var sum=function(num1,num2){
4   return num1+num2;  
5 }

 使用函数表达式定义行数的方式不存在函数声明提升,所以会报出异常。

1 sum(1,2);//TypeError:sum is not a function
2 
3 var sum=new Function('num1','num2','return num1+num2');

使用Function构造函数定义函数的方式不存在函数声明提升,所以会报出异常。

原文地址:https://www.cnblogs.com/PolarisSky/p/5270185.html