Javascript中的高阶函数介绍
2024-08-31 16:11:09
高阶函数:高阶看上去就像是一种先进的编程技术的一个深奥术语,一开始我看到的时候我也这样认为的。
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])
//
最新文章
- vs2013中一: 无法查找或打开 PDB 文件解决办法 二:解决This function or variable may be unsafe
- 20169212《Linux内核原理与分析》第五周作业
- yourphp数据库介绍
- c++(vs上)与g++(linux下)对于++操作的汇编代码解读
- 20150224—ASP.NET基础
- C#控制定位Word光标移动到任意行或者最后一行,取得光标位置等操作
- Linux 常用命令记录
- 手游接入Facebook的那些坑
- html 块状元素 行内元素 内联元素
- 通过history解决ajax不支持前进/后退/刷新
- c++ 中lambda
- C++多态实现原理
- DBoW2应用
- 对thinkphp5.0框架的实例学习
- C# 程序修改config文件后,不重启程序刷新配置ConfigurationManager
- GDAL多光谱与全色图像融合简单使用
- zookeeper和kafka的安装
- 20145105 《Java程序设计》第7周学习总结
- TCC(Tiny C Compiler)介绍
- 【HNOI2007】紧急疏散