高阶函数:高阶看上去就像是一种先进的编程技术的一个深奥术语,一开始我看到的时候我也这样认为的。

Javascript的高阶函数

  然而,高阶函数只是将函数作为参数或返回值的函数。以下面的Hello,World作为一个简单的例子。

var Moqi = function(p1){
this.add = function (p2){
return p1 + ' ' + p2;
};
return add;
};
//我们便可以这样使用这个函数
console.log(Moqi('Hello')('World'));

  或许这个过程有点混乱,看看详细一点的。

typeof Moqi('Hello')
//"function"
Moqi('Hello')
//function (p2){
// return p1 + ' ' + p2;
//}

  也就是说实际上Moqi('Hello')是一个函数,Moqi('Hello')

var m = Moqi('Hello')
m('World')
//"Hello,World"

  从上面的情况来看,高阶函数可以使代码更简洁、高效。自然而然地我们也可以创建下面这样一个函数:

var Moqi = function(p1){
return function (p2){
return function(p3){
return p1 + ',' + p2 + ' ' +p3;
}
};
};
Moqi('Hello')('World')('Phodal')
//"Hello,World Phodal"

还原高阶函数

  越来越复杂,需要引入高阶函数抽象的信号是出现重复或者相似的代码。然后,我们先一步步还原到之前的函数:

var Moqi = function(p1){
this.add = function (p2){
return function(p3){
return p1 + ',' + p2 + ' ' +p3;
}
};
return this.add;
};

  接着再创建一个新的函数

var Moqi = function(p1){
this.add = function (p2){
this.add1 = function(p3){
return p1 + ',' + p2 + ' ' +p3;
};
return this.add1;
};
return this.add;
};

  使用javascript中的call方法,就会有:

var Moqi = function(p1){
var self = this;
function fd(p2) {
this.add1 = function (p3) {
return p1 + ',' + p2 + ' ' + p3;
};
} self.add = function (p2){
fd.call(this, p2);
return this.add1;
};
return self.add;
};

高阶函数实例

add = function(a,b){
return a + b;
}; function math(func,array){
return func(array[],array[]);
} console.log(math(add,[,])); //math(add,[1,2])
//

最新文章

  1. vs2013中一: 无法查找或打开 PDB 文件解决办法 二:解决This function or variable may be unsafe
  2. 20169212《Linux内核原理与分析》第五周作业
  3. yourphp数据库介绍
  4. c++(vs上)与g++(linux下)对于++操作的汇编代码解读
  5. 20150224—ASP.NET基础
  6. C#控制定位Word光标移动到任意行或者最后一行,取得光标位置等操作
  7. Linux 常用命令记录
  8. 手游接入Facebook的那些坑
  9. html 块状元素 行内元素 内联元素
  10. 通过history解决ajax不支持前进/后退/刷新
  11. c++ 中lambda
  12. C++多态实现原理
  13. DBoW2应用
  14. 对thinkphp5.0框架的实例学习
  15. C# 程序修改config文件后,不重启程序刷新配置ConfigurationManager
  16. GDAL多光谱与全色图像融合简单使用
  17. zookeeper和kafka的安装
  18. 20145105 《Java程序设计》第7周学习总结
  19. TCC(Tiny C Compiler)介绍
  20. 【HNOI2007】紧急疏散

热门文章

  1. POJ 3243 Clever Y | BSGS算法完全版
  2. Tomcat学习笔记(十一)
  3. Apache-commons.BeanUtils浅析
  4. 《c程序设计语言》读书笔记-递归实现快速排序算法
  5. Access-Control-Allow-Origin设置多个域名
  6. MySQL基本管理和应用
  7. 使用rssh创建一个安全的文件服务器
  8. C++自带向量_vector_C++
  9. [模板]大步小步算法——BSGS算法
  10. Relation(NOIP模拟赛)(二分图染色)