您现在的位置是:亿华云 > 应用开发

聊聊 Javascript 常见的高阶函数

亿华云2025-10-03 02:13:29【应用开发】5人已围观

简介高阶函数,英文叫 Higher Order function。一个函数可以接收另外一个函数作为参数,这种函数就叫做高阶函数。示例:functionadd(x,y,f){returnf(x)+f(y);

高阶函数,聊聊英文叫 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 是映射的意思。

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

实例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}) 

很赞哦!(7852)