function 函数类型之函数的声明方式

function 函数的声明方式

普通函数的声明

function box(a,b){    
return a+b};    
alert(box(2,3));    


可以看到正常打印了。这是最简单的函数的声明。

使用变量初始化函数

var box = function(a,b){    
return a+b};    
alert(box(2,3));       


这是使用 变量初始化函数。

使用 function 构造函数

var box = new Function('a','b','return a+b');    
alert(box(1,2));      


第三种不推荐使用,因为它会解析两次代码。(第一次是解析常规 ECMAScript 代码,第二次是解析传入构造函数中的字符串)从而影响性能。我们通过这种语法来理解 函数是对象,函数名是指针 的概念。

作为值的函数

因为 ECMAScript中的函数名本身就是变量,所以函数也可以作为值来使用。不仅可以像传递参数那样把一个函数传递给另一个函数,而且可以将另一个函数作为另一个函数的结果返回。
函数可以传递函数,第一个我们写一个传递的函数

function box(sum,num){     
return sum+num;     
}  
    
function sum(num){     
return num+10;     
}      
 
var res = box(sum(10),10);      
document.write(res);


这时候我们把 sum(10)传递的是函数的返回值和普通的变量没区别。所以这时候就是 function sum(10){return 10+10}; 最后返回的是 10+10=20;然后函数 box(sum(10),10)相当于 box(20,10) 所以打印的就是30 .这个例子就是把函数作为返回值传递的,而不是作为函数传递的。
接下来的例子就是要把函数本身作为参数传递,而不是函数的结果传递。

function box(sum,num){     
return sum(num);     
}  
    
function sum(num){     
return num+10;     
}      
 
var res = box(sum,10);      
document.write(res);   


这时候就是把 sum() 函数作为一个值返回。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 第5章 引用类型(返回首页) 本章内容 使用对象 创建并操作数组 理解基本的JavaScript类型 使用基本类型...
    大学一百阅读 3,282评论 0 4
  • 第一章: JS简介 从当初简单的语言,变成了现在能够处理复杂计算和交互,拥有闭包、匿名函数, 甚至元编程等...
    LaBaby_阅读 1,718评论 0 6
  • 本章内容 使用对象 创建并操作数组 理解基本的 JavaScript 类型 使用基本类型和基本包装类型 引用类型的...
    闷油瓶小张阅读 713评论 0 0
  • 有人说过,很多弯路到最后都成了直路,所有的坑到最后也都成了坦途;所谓的直路和坦途并不是摆在眼前的,都是不断的的...
    老衲法号一眉道人阅读 1,404评论 0 4
  • 手指伤了 只不过不能再触碰你 嘴巴伤了 只不过再也说不出甜言蜜语 身体伤了 只不过不能再拥抱你 可心伤了 我真不知...
    皆非_lx阅读 273评论 0 1