JavaScript中reduce()的5个基本用法示例

前言

reduce()方法可以搞定的东西,for循环,或者forEach方法有时候也可以搞定,那为啥要用reduce()?这个问题,之前我也想过,要说原因还真找不到,唯一能找到的是:通往成功的道路有很多,但是总有一条路是最捷径的,亦或许reduce()逼格更高...

语法

arr.reduce(callback,[initialValue])

reduce()方法对数组中的每一个元素执行一个reducer函数(由你提供),从而得到一个单一的输出值。

reduce() 方法将一个数组中的所有元素还原成一个单一的输出值,输出值可以是数字、对象或字符串。 reduce() 方法有两个参数,第一个是 回调函数 ,第二个是 初始值 。

回调函数

回调函数在数组的每个元素上执行。回调函数的返回值是累加结果,并作为下一次调用回调函数的参数提供。回调函数带有四个参数。

  • Accumulator(累加器)——累加器累加回调函数的返回值。
  • Current Value(当前值)——处理数组的当前元素。
  • Current Index(当前索引)——处理数组当前元素的索引。
  • Source Array(源数组)

Current Index 和 Source Array 是可选的。

初始值

如果指定了初始值,则将累加器设置为 initialValue 作为初始元素。否则,将累加器设置为数组的第一个元素作为初始元素。

arr.reduce(callback(accumulator, currentValue[,index[,array]])[, initialValue])

在下面的代码片段中,第一个累加器( accumulator )被分配了初始值0。 currentValue 是正在处理的 numbersArr 数组的元素。在这里, currentValue 被添加到累加器,在下次调用回调函数时,会将返回值作为参数提供。

const numbersArr = [67, 90, 100, 37, 60];

const total = numbersArr.reduce(function(accumulator, currentValue){
 console.log("accumulator is " + accumulator + " current value is " + currentValue);
 return accumulator + currentValue;
}, 0);

console.log("total : "+ total);

输出

accumulator is 0 current value is 67
accumulator is 67 current value is 90
accumulator is 157 current value is 100
accumulator is 257 current value is 37
accumulator is 294 current value is 60
total : 354

JavaScript reduce用例

1.对数组的所有值求和

在下面的代码中, studentResult 数组具有5个数字。使用 reduce() 方法,将数组减少为单个值,该值将 studentResult 数组的所有值和结果分配给 total 。

const studentResult = [67, 90, 100, 37, 60];

const total = studentResult.reduce((accumulator, currentValue) => accumulator +currentValue, 0);

console.log(total); // 354

2.对象数组中的数值之和

通常,我们从后端获取数据作为对象数组,因此, reduce() 方法有助于管理我们的前端逻辑。在下面的代码中, studentResult 对象数组有三个科目,这里, currentValue.marks 取了 studentResult 对象数组中每个科目的分数。

const studentResult = [
 { subject: '数学', marks: 78 },
 { subject: '物理', marks: 80 },
 { subject: '化学', marks: 93 }
];

const total = studentResult.reduce((accumulator, currentValue) => accumulator + currentValue.marks, 0);

console.log(total); // 251

3.展平数组

“展平数组”是指将多维数组转换为一维。在下面的代码中, twoDArr 2维数组被转换为 oneDArr 一维数组。此处,第一个 [1,2] 数组分配给累加器 accumulator ,然后 twoDArr 数组的其余每个元素都连接到累加器。

const twoDArr = [ [1,2], [3,4], [5,6], [7,8] , [9,10] ];

const oneDArr = twoDArr.reduce((accumulator, currentValue) => accumulator.concat(currentValue));

console.log(oneDArr);
// [ 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 ]

4.按属性分组对象

根据对象的属性,我们可以使用 reduce() 方法将对象数组分为几组。通过下面的代码片段,你可以清楚地理解这个概念。这里, result 对象数组有五个对象,每个对象都有 subject 和 marks 属性。如果分数大于或等于50,则该主题通过,否则,主题失败。 reduce() 用于将结果分组为通过和失败。首先,将 initialValue 分配给累加器,然后 push() 方法在检查条件之后将当前对象添加到 pass 和 fail 属性中作为对象数组。

const result = [
 {subject: '物理', marks: 41},
 {subject: '化学', marks: 59},
 {subject: '高等数学', marks: 36},
 {subject: '应用数学', marks: 90},
 {subject: '英语', marks: 64},
];

let initialValue = {
 pass: [],
 fail: []
}

const groupedResult = result.reduce((accumulator, current) => {
 (current.marks >= 50) ? accumulator.pass.push(current) : accumulator.fail.push(current);
 return accumulator;
}, initialValue);

console.log(groupedResult);

输出

{
 pass: [
  { subject: ‘化学', marks: 59 },
  { subject: ‘应用数学', marks: 90 },
  { subject: ‘英语', marks: 64 }
 ],
 fail: [
  { subject: ‘物理', marks: 41 },
  { subject: ‘高等数学', marks: 36 }
 ]
}

5.删除数组中的重复项

在下面的代码片段中,删除了 plicatedArr 数组中的重复项。首先,将一个空数组分配给累加器作为初始值。

accumulator.includes() 检查 duplicatedArr 数组的每个元素是否已经在累加器中可用。如果 currentValue 在累加器中不可用,则使用 push() 将其添加。

const duplicatedsArr = [1, 5, 6, 5, 7, 1, 6, 8, 9, 7];

const removeDuplicatedArr = duplicatedsArr.reduce((accumulator, currentValue) => {
 if(!accumulator.includes(currentValue)){
 accumulator.push(currentValue);
 }
 return accumulator;
}, []);

console.log(removeDuplicatedArr);
// [ 1, 5, 6, 7, 8, 9 ]

总结

在本文中,我们讨论了数组 reduce() 方法。首先介绍 reduce() 方法,然后,使用一个简单的示例讨论其行为。最后,通过示例讨论了 reduce() 方法最常见的五个用例。如果你是JavaScript的初学者,那么本文将对你有所帮助。

到此这篇关于JavaScript中reduce()的5个基本用法示例的文章就介绍到这了,更多相关JavaScript reduce()用例内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

时间: 2020-07-18

js中的reduce()函数讲解

定义: reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值.对空数组是不会执行回调函数的. 案例 1.数组求和 // 1.数组求和 var arr = [1,5,8,6,15,78,65,25,48,55] var sum = arr.reduce(function(total,currentValue){ return total+currentValue; }); console.log(sum);//306 var eachSum = 0;

JS数组Reduce方法功能与用法实例详解

本文实例讲述了JS数组Reduce方法功能与用法.分享给大家供大家参考,具体如下: 概述 一直以来都在函数式编程的大门之外徘徊,要入门的话首先得熟悉各种高阶函数,数组的reduce方法就是其中之一. reduce方法将会对数组元素从左到右依次执行reducer函数,然后返回一个累计的值.举个形象的例子:你要组装一台电脑,买了主板.CPU.显卡.内存.硬盘.电源...这些零件是组装电脑的必要条件. 装的过程可以简单概括为拆掉每个零件的包装,再装到一起.类比一下reduce函数就可以明白了,那些零件

js数组方法reduce经典用法代码分享

以下是个人在工作中收藏总结的一些关于javascript数组方法reduce的相关代码片段,后续遇到其他使用这个函数的场景,将会陆续添加,这里作为备忘. javascript数组那么多方法,为什么我要单挑reduce方法,一个原因是我对这个方法掌握不够,不能够用到随心所欲.另一个方面,我也感觉到了这个方法的庞大魅力,在许多的场景中发挥着神奇的作用. 理解reduce函数 reduce() 方法接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始缩减,最终为一个值. a

详解JavaScript中数组的reduce方法

介绍 我们先来看看这个方法的官方概述:reduce() 方法接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始缩减,最终为一个值. 你一定也和我一样看的有点迷糊,其实reduce接收的就是一个回调函数,去调用数组里的每一项,直到数组结束. 我们来举个例子大家就很明白了. 假设我有一串数组,数组里放的全是数字,我要算出这些数字的总和是多少.正常情况下我们会循环,然后一个个加,有了reduce就不用那么麻烦了,只用一行代码. var total = [0,1,2,3,4

JavaScript中自带的 reduce()方法使用示例详解

1.方法说明 , Array的reduce()把一个函数作用在这个Array的[x1, x2, x3...]上,这个函数必须接收两个参数,reduce()把结果继续和序列的下一个元素做累积计算,其效果就是: [x1, x2, x3, x4].reduce(f) = f(f(f(x1, x2), x3), x4) 2. 使用示例 'use strict'; function string2int(s){ if(!s){ alert('the params empty'); return; } if

解析JavaScript数组方法reduce

Array.prototype.reduce() 概述 reduce()方法是数组的一个实例方法(共有方法),可以被数组的实例对象调用.reduce() 方法接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始缩减,最终为一个值. 语法 arr.reduce(callback[, initialValue]) {} 参数 回调函数中可以传递四个参数. previousValue:上一次调用回调函数返回的值,或者是提供的初始值(initialValue) current

Javascript数组方法reduce的妙用之处分享

前言 Javascript数组方法中,相比map.filter.forEach等常用的迭代方法,reduce常常被我们所忽略,今天一起来探究一下reduce在我们实战开发当中,能有哪些妙用之处,下面从reduce语法开始介绍. 语法 array.reduce(function(accumulator, arrayElement, currentIndex, arr), initialValue) 若传入初始值,accumulator首次迭代就是初始值,否则就是数组的第一个元素:后续迭代中将是上一

详解JS数组Reduce()方法详解及高级技巧

基本概念 reduce() 方法接收一个函数作为累加器(accumulator),数组中的每个值(从左到右)开始缩减,最终为一个值. reduce 为数组中的每一个元素依次执行回调函数,不包括数组中被删除或从未被赋值的元素,接受四个参数:初始值(或者上一次回调函数的返回值),当前元素值,当前索引,调用 reduce 的数组. 语法: arr.reduce(callback,[initialValue]) callback (执行数组中每个值的函数,包含四个参数) previousValue (上

Javascript中内建函数reduce的应用详解

前言 一般而言,可以通过reduce方法实现的逻辑都可以通过forEach方法来变相的实现,虽然不清楚浏览器的js引擎是如何在C++层面实现这两个方法,但是可以肯定的是reduce方法肯定也存在数组的遍历,在具体实现细节上是否针对数组项的操作和存储做了什么优化,则不得而知. 数组的reduce方法的应用 reduce方法有两个参数,第一个参数是一个callback,用于针对数组项的操作:第二个参数则是传入的初始值,这个初始值用于单个数组项的操作.需要注意的是,reduce方法返回值并不是数组,而

JavaScript中reduce()方法的使用详解

JavaScript 数组reduce()方法同时应用一个函数针对数组的两个值(从左到右),以减至一个值. 语法 array.reduce(callback[, initialValue]); 下面是参数的详细信息: callback : 函数执行在数组中每个值 initialValue : 对象作为第一个参数回调的第一次调用使用 返回值: 返回数组的减少单一个值 兼容性: 这种方法是一个JavaScript扩展到ECMA-262标准; 因此它可能不存在在标准的其他实现.为了使它工作,你需要添加

JavaScript中toString()方法的使用详解

JavaScript Boolean.toSource()方法返回表示对象的源代码的字符串. 注意:此方法不会在Internet Explorer中运行. 语法 boolean.toSource() 下面是参数的详细信息: NA 返回值 返回表示对象的源代码的字符串. 例子: <html> <head> <title>JavaScript toSource() Method</title> </head> <body> <scr

JavaScript中getUTCSeconds()方法的使用详解

javascript Date.getUTCSeconds()方法返回按照通用时间在指定日期的秒.通过getUTCSeconds返回的值是0到59之间的一个整数. 语法 Date.getUTCSeconds() 下面是参数的详细信息: NA 返回值: 按照通用时间返回在指定的日期的秒数. 例子: 下面的例子中打印当前时间给变量hrs的秒数部分. <html> <head> <title>JavaScript getUTCSeconds Method</title&

JavaScript中setMonth()方法的使用详解

javascript Date.setMonth()方法按照本地时间设置每月指定日期. 语法 Date.setMonth(monthValue[, dayValue]) 注:括号内外观和数据是可选的 下面是参数的详细信息: monthValue : 从0到11的整数(表示个月份,从一月到十二月). dayValue : 从1到31的整数,代表一个月中的某天. msValue : 一个数字0和999之间,表示毫秒.如果指定msValue参数,则还必须指定minutesValue和secondsVa

JavaScript中setFullYear()方法的使用详解

javascript Date.setFullYear()方法按照本地时间的将指定全年的日期. 语法 Date.setFullYear(yearValue[, monthValue[, dayValue]]) 注:括号内的参数是可选 下面是参数的详细信息: yearValue : 一个整数,指定年份的数字值,例如,2008年 monthValue : 从0到11的整数表示的月份一月到十二月 dayValue : 1到31之间的整数,表示一个月的一天.如果指定dayValue参数,则还必须指定mo

JavaScript中getUTCMinutes()方法的使用详解

javascript Date.getUTCMinutes()方法按照通用时间在指定日期返回分钟.通过getUTCMinutes返回的值是0到59之间的一个整数. 语法 Date.getUTCMinutes() 下面是参数的详细信息: NA 返回值: 按照通用时间返回分钟,在指定的日期. 例子: 下面的例子打印的当前时间变量hrs的分钟部分. <html> <head> <title>JavaScript getUTCMinutes Method</title&g

JavaScript中setUTCMilliseconds()方法的使用详解

javascript Date.setUTCMilliseconds()方法按照通用时间设置毫秒指定日期. 语法 Date.setUTCMilliseconds(millisecondsValue) 注:括号内外的数据是可选的 下面是参数的详细信息: millisecondsValue : 一个数字在0和999之间,表示毫秒. 如果指定的参数是预期范围之外,setUTCMilliseconds尝试相应地更新Date对象的最新信息.例如,如果 millisecondsValue 使用1100,存储

JavaScript中push(),join() 函数 实例详解

定义和用法 push方法 可向数组的末尾添加一个或多个元素,并返回一个新的长度. join方法 用于把数组中所有元素添加到一个指定的字符串,元素是通过指定的分隔符进行分割的. 语法 arrayObject.push(newelement1,newelement2,....,newelementX) arrayObject.join(separator). 参数描述newelement1必需.要添加到数组的第一个元素.newelement2可选.要添加到数组的第二个元素.newelementX可选

JavaScript中浅讲ajax图文详解

1.ajax入门案例 1.1 搭建Web环境 ajax对于各位来说,应该都不陌生,正因为ajax的产生,导致前台页面和服务器之间的数据传输变得非常容易,同时还可以实现页面的局部刷新.通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新.这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新. 对于JavaWeb项目而言,ajax主要用于浏览器和服务器之间数据的传输. 如果是单单地堆砌知识点,会显得比较无聊,那么根据惯例,我先不继续介绍ajax,而是来写一个案例吧. 打开