Array.reduce()方法详解及高级技巧 您所在的位置:网站首页 js二维数组求和 Array.reduce()方法详解及高级技巧

Array.reduce()方法详解及高级技巧

2023-11-18 06:14| 来源: 网络整理| 查看: 265

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

1.语法 arr.reduce(callback, [initialValue])

reduce为数组中的每一个元素依次执行回调函数,不包括数组中被删除或从未被赋值的元素,接受四个参数:初始值(或者上一次回调函数的返回值),当前元素值,当前索引,调用reduce的数组。

callback (执行数组中每个值的函数,包含四个参数) 1、previousValue (上一次调用回调返回的值,或者是提供的初始值(initialValue)) 2、currentValue (数组中当前被处理的元素) 3、index (当前元素在数组中的索引) 4、array (调用 reduce 的数组) initialValue (作为第一次调用 callback 的第一个参数)。 2.实例解析 initialValue 参数

先看第一个例子

const arr = [1, 2, 3, 4]; const sum = arr.reduce((prev, cur, index, arr) => { console.log(prev, cur, index); return prev + cur; }) console.log(arr, sum); 打印结果: 1 2 1 3 3 2 6 4 3 [1, 2, 3, 4] 10

这里可以看出,上面的例子index是从1开始的,第一次的prev的值是数组的第一个值。数组长度是4,但是reduce函数循环3次。

再看第二个例子:

const arr = [1, 2, 3, 4]; const sum = arr.reduce((prev, cur, index, arr) => { console.log(prev, cur, index); return prev + cur; },0) //注意这里设置了初始值 console.log(arr, sum); 打印结果: 0 1 0 1 2 1 3 3 2 6 4 3 [1, 2, 3, 4] 10

这个例子index是从0开始的,第一次的prev的值是我们设置的初始值0,数组长度是4,reduce函数循环4次。

结论:如果没有提供initialValue,reduce会从索引1的地方开始执行callback方法,跳过第一个索引。如果提供initialValue,从索引0开始。

注意:如果这个数组为空,运用reduce是什么情况?

const arr = []; const sum = arr.reduce((prev, cur, index, arr) => { console.log(prev, cur, index); return prev + cur; }) //报错,"TypeError: Reduce of empty array with no initial value"

所以一般来说我们提供初始值通常会更安全

3.reduce的简单用法

当然最简单的就是我们常用的数组求和,求乘积了。

const arr = [1, 2, 3, 4]; const sum = arr.reduce((x,y) => x+y) const mul = arr.reduce((x,y) => x*y) console.log( sum ); //求和,10 console.log( mul ); //求乘积,24 4.reduce的高级用法

1.计算数组中每个元素出现的次数

const names = ['A', 'B', 'C', 'D', 'A']; const nameNum = names.reduce((pre,cur) => { if(cur in pre) { pre[cur]++ } else { pre[cur] = 1 } return pre },{}) console.log(nameNum); //{A: 2, B: 1, C: 1, D: 1}

2.数组去重

const arr = [1,2,2,4,4,1] const newArr = arr.reduce((pre,cur) => { if(!pre.includes(cur)) { return pre.concat(cur) } else { return pre } },[]) console.log(newArr);// [1, 2, 4]

3.将二维数组转化为一维

const arr = [[0, 1], [2, 3], [4, 5]] const newArr = arr.reduce((pre,cur) => { return pre.concat(cur) },[]) console.log(newArr); // [0, 1, 2, 3, 4, 5]

4.对象里的属性求和

const result = [ { subject: '语文', score: 90 }, { subject: '数学', score: 90 }, { subject: '英语', score: 100 } ]; const sum = result.reduce((prev, cur) => { return cur.score + prev; }, 0); console.log(sum) //280


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有