ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Javascript 常见的高阶函数

2021-09-28 09:35:14  阅读:161  来源: 互联网

标签:return 函数 Javascript filter item let 数组 高阶


高阶函数,英文叫 Higher Order function。一个函数可以接收另外一个函数作为参数,这种函数就叫做高阶函数。

示例:

function add(x, y, f) {
 return f(x) + f(y);
}

//用代码验证一下:
add(-5, 6, Math.abs); // 11

一、常见的高阶函数

ES6中数组新增了几种方法,其中 map、reduce、filter 几个都是高阶函数,除此,普通的sort也是高阶函数。分别介绍下新增的三个方法。

1.1、filter

filter 是过滤数组,返回满足条件的数据,组成一个新的数组返回,不满足条件的被丢弃。

实例1:取出数组中小于 100 的数据,放到一个新数组中

let grad = [ 102, 188, 55, 66, 200, 800 ]
let arr2 = grad.filter( function(item){
 return item <= 100
})
console.log("arr2",arr2)// 55, 66

上述实例中,filter传入的参数是一个函数,传入的函数依次作用于每个元素,然后根据返回值是 true 或 false 决定保留还是丢弃元素。因为只有 55 66 两个满足条件,所以新的数组中只有这两个元素。

1.2、map

map 是映射的意思。

原数组被映射成一个新的数组,返回值是一个新数组,不改变原来的数组。新的数组与原数组的长度是不会改变的。

实例2:给数据每个元素放大 2 倍。

let arr2 = [ 55, 66 ]
let arr3 = arr2.map( item => {
 return item*2
})
//返回结果 [ 110, 132 ]

上述实例,map接收的参数是一个函数,该函数依次作用于每个元素,对元素放大了2倍,也可以对其进行任意的复杂操作。

1.3、reduce

reduce 是对数组进行汇总的,往往进去一个数组,出来是一个数据。经常用于求和和计算平均值。

实例3:对上个实例返回的结果进行求和。

let sum = arr3.reduce((tmp,item)=>{
 return tmp+item
})
//返回结果 242

重点来了,如果我们想把上边三个实例合并到一起执行,最终我们可以写得有多简单呢?

// 复杂写法
let grad = [102,188,55,66,200,800]
let arr2 = grad.filter(function(item){
 return item <= 100
})
let arr3 = arr2.map(item=>{
 return item*2
})
let sum = arr3.reduce((tmp,item)=>{
 return tmp+item
})
//简单写法
let sum2 = grad
           .filter( item => {return item <= 100})
          .map(item=>{return item*2})
          .reduce((tmp,item)=>{return tmp+item})

 

 

标签:return,函数,Javascript,filter,item,let,数组,高阶
来源: https://www.cnblogs.com/web-learn/p/15346324.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有