码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2016-03-12 22:55:27      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:

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

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构造函数定义函数的方式不存在函数声明提升,所以会报出异常。

 

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

标签:

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!