JavaScript中的高阶函数
之前写的《JavaScript学习手册》,客户跟我说有些内容不适合初学者,让我删了,感觉挺可惜的,拿到这里和大家分享。
JavaScript中的一切都是对象,这句话同样适用于函数。函数对象可以作为函数的参数。
一 函数对象作为另一个函数的参数
函数可以作为另外一个函数的参数,这里的“另外一个函数”可以返回具体的值,也可以返回一个函数。第二种情况就是函数的函数,称为高阶函数。在介绍这两种情况之前,先了解一下 call() 和 apply() 方法:
call() 的使用方式为 被调用的函数.call(调用者,参数1,参数2....),功能为:调用者调用被调用的函数,并传入参数列表。
apply() 的使用方式为 被调用的函数.apply(调用者,参数组成的数组),功能为:调用者调用被调用的函数,并传入参数数组。
call() 和 apply() 里面如果传入的第一个参数是 this ,表示的是函数的调用者。
var store = {name:"myStore", id:5622};
function getSalesVolume(a, b) {
return a + b;
}
//store后面有两个参数
getSalesVolume.call(store, 40000, 50000);//返回90000
//store后面是一个参数数组,长度为2
getSalesVolume.apply(store, [40000, 50000]);//返回90000
二 返回值
一个函数作为另外一个函数的参数,并最终返回一个值。
//求最大值
function getMax(a, b) {
return a > b ? a : b;
}
//求最小值
function getMin(a, b) {
return a < b ? a : b;
}
//下面这个函数以函数作为参数,并最终返回一个值
function getM(func, num1, num2) {
return func(num1, num2);
}
getM(getMax, 1, 2);//返回2
getM(getMin, 1, 2);//返回1
getM() 的第一个参数是函数的名字,但是不能用双引号包含在内。
三 高阶函数
高阶函数的输入是函数,输出也是函数。即一个函数调用另外一个函数,然后返回一个新的函数。比如通过调用求两个数的最大值的函数,实现求n个数的最大值的函数,就可以用到高阶函数来实现:
//求最大值
function twoMax(a, b) {
return a > b ? a : b;
}
function getMax(func) {
return function() { //返回一个匿名函数
var aLength = arguments.length;
var result = 0;
for (var i = 0;i < aLength;i++) {
result = func.call(this, result, arguments[i]);
}
return result;
};
}
var multiMax = getMax(twoMax);
console.log(multiMax(1, 2, 3, 4));//输出4
上面的 getMax() 函数在传入实参 twoMax() 函数后,会返回一个新的函数 multiMax() ,用来求多个数的最大值。getMax() 每次求两个数的最大值,然后再将这个最大值与第三个数比较,求最大值,这样一直进行下去,就可以求得多个数的最大值。
JavaScript中的高阶函数的更多相关文章
- 如何在JavaScript中使用高阶函数
将另一个函数作为参数的函数,或者定义一个函数作为返回值的函数,被称为高阶函数. JavaScript可以接受高阶函数.这种处理高阶函数的能力以及其他特点,使JavaScript成为非常适合函数式编程的 ...
- javascript中的高阶函数, 和 类定义Function, 和apply的使用
参考: http://www.cnblogs.com/delin/archive/2010/06/17/1759695.html js中的类, 也是用function关键字来定义的: function ...
- Javascript中的高阶函数介绍
高阶函数:高阶看上去就像是一种先进的编程技术的一个深奥术语,一开始我看到的时候我也这样认为的. Javascript的高阶函数 然而,高阶函数只是将函数作为参数或返回值的函数.以下面的Hello,Wo ...
- Javascript 闭包与高阶函数 ( 二 )
在上一篇 Javascript 闭包与高阶函数 ( 一 )中介绍了两个闭包的作用. 两位大佬留言指点,下来我会再研究闭包的实现原理和Javascript 函数式编程 . 今天接到头条 HR 的邮件,真 ...
- JavaScript进阶之高阶函数篇
JavaScript进阶之高阶函数篇 简介:欢迎大家来到woo爷说前端:今天给你们带来的是JavaScript进阶的知识,接下来的系列都是围绕着JavaScript进阶进行阐述:首先我们第一篇讲的是高 ...
- JS中的高阶函数
JS中的高阶函数 高阶函数是指以函数作为参数的函数,并且可以将函数作为结果返回的函数. 1. 高阶函数 接受一个或多个函数作为输入 输出一个函数 至少满足以上一个条件的函数 在js的内置对象中同样存在 ...
- Python 函数式编程 & Python中的高阶函数map reduce filter 和sorted
1. 函数式编程 1)概念 函数式编程是一种编程模型,他将计算机运算看做是数学中函数的计算,并且避免了状态以及变量的概念.wiki 我们知道,对象是面向对象的第一型,那么函数式编程也是一样,函数是函数 ...
- Python中的高阶函数与匿名函数
Python中的高阶函数与匿名函数 高阶函数 高阶函数就是把函数当做参数传递的一种函数.其与C#中的委托有点相似,个人认为. def add(x,y,f): return f( x)+ f( y) p ...
- Java中的函数式编程(五)Java集合框架中的高阶函数
写在前面 随着Java 8引入了函数式接口和lambda表达式,Java 8中的集合框架(Java Collections Framework, JCF)也增加相应的接口以适应函数式编程. 本文的 ...
随机推荐
- [Swift]LeetCode335. 路径交叉 | Self Crossing
You are given an array x of n positive numbers. You start at point (0,0) and moves x[0] metres to th ...
- [Swift]LeetCode482. 密钥格式化 | License Key Formatting
You are given a license key represented as a string S which consists only alphanumeric character and ...
- [Swift]LeetCode526. 优美的排列 | Beautiful Arrangement
Suppose you have N integers from 1 to N. We define a beautiful arrangement as an array that is const ...
- 英语笔记3(git)
备注 一: Staging Modified Files Let’s change a file that was already tracked. (tracked 表示该文件已经被git管理过,再 ...
- [usaco18Feb] New Barns
题意 每次新建一个节点,并与一个已知节点连边.(或者不连).多次询问以某个已知点点出发的最远路径长度. 分析 显然,在任何时候图都是一个森林.由树的直径算法可知,与某点最远距的点必然是树的直径的一段. ...
- Android 普通通知栏新方法,现在需要创建通知渠道才可以
先看看效果看看是不是你想要的 点击后 话不多所,贴代码 xml文件: <?xml version="1.0" encoding="utf-8"?>& ...
- 【朝花夕拾】Android性能篇之(二)Java内存分配
前言 在内存方面,相比于C/C++程序员,咱们java系程序员算是比较幸运的,因为对于内存的分配和回收,都交给了JVM来处理了,而不需要手动在代码中去完成.有了虚拟机内存管理机制,也就不 ...
- CentOS安装FTP服务
最近公司有一个内部比赛(黑客马拉松),报名参加了这么一个赛事,在准备参赛作品的同时(参赛服务器需要自己搭建),借着这个机会,决定把tomcat部署相关的知识从0到1重新捋一遍.就当备忘录了. FTP服 ...
- [Leetcode]112. Path Sum -David_Lin
Given a binary tree and a sum, determine if the tree has a root-to-leaf path such that adding up all ...
- Python的魔法函数
概要 如何定义一个类 类里通常包含什么 各个部分解释 类是怎么来的 type和object的关系 判断对象的类型 上下文管理器 类结构 #!/usr/bin/env python # -*- codi ...