我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Javascript 常见的高阶函数详情

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Javascript 常见的高阶函数详情

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

示例:


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

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

一、常见的高阶函数

ES6中数组新增了几种方法,其中 mapreducefilter 几个都是高阶函数,除此,普通的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})

到此这篇关于Javascript 常见的高阶函数详情的文章就介绍到这了,更多相关Javascript 常见的高阶函数内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Javascript 常见的高阶函数详情

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python常见内置高阶函数有哪些

这篇文章给大家分享的是有关Python常见内置高阶函数有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。1.什么是高阶函数?  高阶函数:一个函数可以作为参数传给另外一个函数,或者一个函数的返回值为另外一个函数
2023-06-21

JavaScript数组对象高阶函数reduce的妙用详解

这篇文章主要为大家介绍了JavaScript数组对象高阶函数reduce的妙用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-05-16

javascript高阶函数指的是什么

这篇文章主要介绍了javascript高阶函数指的是什么,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。说明1、可以将函数作为参数传递给另一个函数。将函数作为另一个函数的返回结
2023-06-20

常用的python高阶函数有哪些

常用的Python高阶函数包括:1. map(function, iterable):对可迭代对象中的每个元素应用函数,并返回一个迭代器。2. filter(function, iterable):对可迭代对象中的每个元素应用函数,并返回一
2023-08-09

8个JavaScript中高阶函数的运用分享

高阶函数是指以函数作为参数的函数,并且可以将函数作为结果返回的函数。本文整理了8个JavaScript中高阶函数的运用,需要的可以参考一下
2023-05-16

C++ 函数参数详解:高阶函数中参数传递的范例

c++++ 中有两种参数传递机制:传值传递和传址传递。传址传递将对象的内存地址传递给函数,而传值传递将值的副本传递给函数。高阶函数是接受函数作为参数的函数,其参数传递需要特别注意,因为传递的函数可能具有不同的参数签名和返回类型。示例中,st
C++ 函数参数详解:高阶函数中参数传递的范例
2024-04-27

PHP 函数常见错误的详细解析

php 函数常见的错误有:函数不存在:调用未定义的函数,解决方法是确保函数已定义或已包含。参数类型不匹配:传递的参数类型与函数签名不匹配,解决方法是传递正确类型的数据。错误的参数数量:参数数量不正确,解决方法是检查函数签名并传递正确数量的参
PHP 函数常见错误的详细解析
2024-04-11

从柯里化分析JavaScript重要的高阶函数实例

这篇文章主要为大家介绍了从柯里化分析JavaScript重要的高阶函数实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2022-11-13

C++ 函数调试详解:如何修复常见的函数错误?

c++++ 函数调试可通过设置断点、打印调试消息和使用调试器识别函数错误,如函数定义缺失、函数签名错误、内存访问错误和逻辑错误。常见的调试技术包括在代码中设置断点、使用 cout/cerr 输出调试消息,以及借助 gdb、lldb 等调试器
C++ 函数调试详解:如何修复常见的函数错误?
2024-05-05

PHP 函数常见错误的错误代码详解

php 函数常见错误代码详解:错误代码 2:语法错误,如缺少分号。错误代码 5:访问未定义变量。错误代码 8:分配给未定义变量。错误代码 9:包含错误,如语法错误或找不到文件。错误代码 16:对象不存在。PHP 函数常见错误的错误代码详解
PHP 函数常见错误的错误代码详解
2024-04-11

编程热搜

目录