reduce 方法的简单使用

reduce() 方法对数组中的每个元素按序执行一个提供的 reducer 函数,每一次运行 reducer 会将先前元素的计算结果作为参数传入,最后将其结果汇总为单个返回值。

今天我们就介绍一下 reduce 的几种简单使用场景。

求数组的累计值

简单数组的累计值获取:

javascript 复制代码
const arr = [12, 3, 7, 34, 6, 22, 15];
const total = arr.reduce((acc, cur) => acc + cur, 0);
console.log(total); // 99

复杂数组的累计值获取:

javascript 复制代码
const people = [
    { name: "Alice", age: 21 },
    { name: "Max", age: 20 },
    { name: "Jane", age: 20 }
];
const ages = people.reduce((acc, cur) => acc + cur.age, 0);
console.log(ages); // 61

按属性对对象进行分组

假设有以下数组:

javascript 复制代码
const people = [
    { name: "Alice", age: 21 },
    { name: "Max", age: 20 },
    { name: "Jane", age: 20 }
];

现要求根据年龄值将上面的数组换换为对象,返回格式为 年龄值:obj。使用 reduce 的实现代码如下:

javascript 复制代码
const ageGroups = people.reduce((acc, cur) => {
    const age = cur.age;
    if (!acc[age]) {
        acc[age] = [];
    }
    acc[age].push(cur.name);
    return acc;
}, {});

console.log(ageGroups);
// {
//     20: ["Max", "Jane"],
//     21: ["Alice"]
// }

展开嵌套数组

我们可以利用 reduce 会累积的特性,逐层展开嵌套数组:

javascript 复制代码
const arr = [
    [0, 1],
    [2, 3],
    [4, 5, 6,7]
];

const flattenArr = arr.reduce((acc, cur) => acc.concat(cur), []);
console.log(flattenArr);
// [0, 1, 2, 3, 4, 5, 6, 7]
相关推荐
qq_54702617911 分钟前
Flowable 工作流引擎
java·服务器·前端
刘逸潇200539 分钟前
CSS基础语法
前端·css
吃饺子不吃馅2 小时前
[开源] 从零到一打造在线 PPT 编辑器:React + Zustand + Zundo
前端·svg·图形学
小马哥编程3 小时前
【软考架构】案例分析-Web应用设计(应用服务器概念)
前端·架构
鱼与宇3 小时前
苍穹外卖-VUE
前端·javascript·vue.js
啃火龙果的兔子3 小时前
前端直接渲染Markdown
前端
z-robot3 小时前
Nginx 配置代理
前端
用户47949283569153 小时前
Safari 中文输入法的诡异 Bug:为什么输入 @ 会变成 @@? ## 开头 做 @ 提及功能的时候,测试同学用 Safari 测出了个奇怪的问题
前端·javascript·浏览器
没有故事、有酒3 小时前
Ajax介绍
前端·ajax·okhttp
朝新_3 小时前
【SpringMVC】详解用户登录前后端交互流程:AJAX 异步通信与 Session 机制实战
前端·笔记·spring·ajax·交互·javaee