JS之数组中的reduce方法

文章目录

      • 基本语法:
      • [callbackFn 的参数:](#callbackFn 的参数:)
      • 例子
        • [1. 数组求和](#1. 数组求和)
        • [2. 数组求积](#2. 数组求积)
        • [3. 扁平化数组](#3. 扁平化数组)
        • [4. 数组元素计数](#4. 数组元素计数)
        • [5. 使用对象解构和展开运算符合并数组中的对象](#5. 使用对象解构和展开运算符合并数组中的对象)
        • [6. 求最大值和最小值](#6. 求最大值和最小值)
      • 函数组合
      • [异步操作中的 `reduce`](#异步操作中的 reduce)
      • 总结

reduce 是 JavaScript 中 Array 对象的一个方法,非常强大且多用途。它可以对数组中的每个元素执行一个提供的回调函数,并且将结果汇总为一个单一的输出值。

基本语法:

javascript 复制代码
array.reduce(callbackFn, initialValue);
  • callbackFn: 一个回调函数,用于计算的每一步,它接收四个参数。
  • initialValue (可选): 作为第一次调用 callbackFn 时第一个参数的值。如果没有提供 initialValue,则 reduce 会从数组的第二个元素开始执行 callbackFn,且 accumulator 会被初始化为数组的第一个元素。

callbackFn 的参数:

javascript 复制代码
function callbackFn(accumulator, currentValue, currentIndex, array) {
  // ...
}
  • accumulator: 累计器,用来累计回调的返回值,是累计的结果。
  • currentValue: 数组中正在处理的当前元素。
  • currentIndex (可选): 数组中正在处理的当前元素的索引。
  • array (可选): 调用 reduce 的数组。

例子

1. 数组求和

计算数组中所有元素的和:

javascript 复制代码
const numbers = [1, 2, 3, 4, 5];
const sum = numbers.reduce((accumulator, currentValue) => accumulator + currentValue, 0);
console.log(sum); // 输出: 15
2. 数组求积

计算数组中所有元素的积:

javascript 复制代码
const numbers = [1, 2, 3, 4, 5];
const product = numbers.reduce((accumulator, currentValue) => accumulator * currentValue, 1);
console.log(product); // 输出: 120
3. 扁平化数组

将一个二维数组扁平化为一维数组:

javascript 复制代码
const arrays = [[1, 2], [3, 4], [5, 6]];
const flattened = arrays.reduce((accumulator, currentValue) => accumulator.concat(currentValue), []);
console.log(flattened); // 输出: [1, 2, 3, 4, 5, 6]
4. 数组元素计数

统计数组中每个元素的出现次数:

javascript 复制代码
const fruits = ['apple', 'banana', 'apple', 'orange', 'banana', 'apple'];
const fruitCount = fruits.reduce((accumulator, currentValue) => {
  if (accumulator[currentValue]) {
    accumulator[currentValue]++;
  } else {
    accumulator[currentValue] = 1;
  }
  return accumulator;
}, {});
console.log(fruitCount); // 输出: { apple: 3, banana: 2, orange: 1 }
5. 使用对象解构和展开运算符合并数组中的对象

假设你有一个包含了一些对象的数组,现在你想合并这些对象:

javascript 复制代码
const objects = [{ a: 1 }, { b: 2 }, { c: 3 }];
const mergedObject = objects.reduce((accumulator, currentValue) => {
  return { ...accumulator, ...currentValue };
}, {});
console.log(mergedObject); // 输出: { a: 1, b: 2, c: 3 }
6. 求最大值和最小值

在数组中找出最大值和最小值:

javascript 复制代码
const numbers = [1, 2, 3, 4, 5];

// 最大值
const max = numbers.reduce((accumulator, currentValue) => Math.max(accumulator, currentValue));
console.log(max); // 输出: 5

// 最小值
const min = numbers.reduce((accumulator, currentValue) => Math.min(accumulator, currentValue));
console.log(min); // 输出: 1

函数组合

通过 reduce 实现函数组合(compose pattern):

javascript 复制代码
const compose = (...funcs) => initialValue =>
  funcs.reduceRight((accumulator, func) => func(accumulator), initialValue);

// 示例函数
const add5 = x => x + 5;
const multiply = x => x * 2;

const composedFunc = compose(multiply, add5);
console.log(composedFunc(10)); // 输出: 30 (首先 add5(10) 得到 15,然后 multiply(15) 得到 30)

异步操作中的 reduce

虽然 reduce 本身是同步的,但你也可以在异步场景中结合 async/await 使用:

javascript 复制代码
const urls = ['url1', 'url2', 'url3'];

async function fetchUrl(url) {
  // 模拟异步 fetch 操作
  return new Promise((resolve) => setTimeout(() => resolve(`Data from ${url}`), 1000));
}

async function fetchData() {
  const results = await urls.reduce(async (accumulatorPromise, url) => {
    const accumulator = await accumulatorPromise;
    const data = await fetchUrl(url);
    accumulator.push(data);
    return accumulator;
  }, Promise.resolve([]));

  console.log(results); // ["Data from url1", "Data from url2", "Data from url3"]
}

fetchData();

总结

reduce 是一个功能非常强大的高阶函数,可以用来解决各种数组操作和数据处理问题。通过理解它的工作原理和灵活运用 callback 函数,你可以编写出简洁高效且具有高度表达力的代码。

相关推荐
草履虫建模2 小时前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
华玥作者4 小时前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
naruto_lnq4 小时前
分布式系统安全通信
开发语言·c++·算法
Mr Xu_4 小时前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠5 小时前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
学嵌入式的小杨同学5 小时前
【Linux 封神之路】信号编程全解析:从信号基础到 MP3 播放器实战(含核心 API 与避坑指南)
java·linux·c语言·开发语言·vscode·vim·ux
sleeppingfrog5 小时前
zebra通过zpl语言实现中文打印(二)
javascript
lang201509285 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
Re.不晚5 小时前
Java入门17——异常
java·开发语言
精彩极了吧5 小时前
C语言基本语法-自定义类型:结构体&联合体&枚举
c语言·开发语言·枚举·结构体·内存对齐·位段·联合