reduce常用来做累计,大部分业务场景下,reduce可以实现的功能通过forEach、map等遍历也可以实现。
1、语法摘要
array.reduce(callback(accumulator, currentValue[, index[, array]])[, initialValue])
-
callback
执行数组中每个值 (如果没有提供 initialValue则第一个值除外)的函数,包含四个参数:-
accumulator
累计器累计回调的返回值; 它是上一次调用回调时返回的累积值,或initialValue(见于下方)。 -
currentValue
数组中正在处理的元素。 -
index 可选
数组中正在处理的当前元素的索引。 如果提供了initialValue,则起始索引号为0,否则从索引1起始。 -
array可选
调用reduce()的数组
-
accumulator
-
initialValue可选
作为第一次调用 callback函数时的第一个参数的值。 如果没有提供初始值,则将使用数组中的第一个元素。 在没有初始值的空数组上调用 reduce 将报错。
reduce() 方法对数组中的每个元素执行一个由您提供的reducer函数(升序执行),将其结果汇总为单个返回值。每次执行的返回值为新的accumulator。
2、实例解析
-
求和
let arr = [ { value: 10, id: 1 }, { value: 20, id: 2 }, { value: 30, id: 3 }, { value: 40, id: 4 }, { value: 50, id: 5 }, ] let yy = arr.reduce((sum, current) => { return sum + current.id }, 0) console.log(yy); // 15 为所有id的和
-
把数组转化为对象映射,某些业务场景下可能需要
const data = [ {id: 100, name: '张三'}, {id: 200, name: '李四'}, {id: 300, name: '王五'} ]; const result = data.reduce((acc, el, i) => { acc[el.name] = el.id; return acc; }, {}); console.log(result) //{张三: 100, 李四: 200, 王五: 300}
-
数组去重
let names = [ '周杰伦', '孙燕姿', '陈奕迅', '周华健', '孙燕姿', '周华健', '周杰伦', ] let newNames = names.reduce((acc, el, index) => { if (!acc.includes(el)) { acc.push(el); return acc; } else { return acc; } }, []) console.log(newNames); // ["周杰伦", "孙燕姿", "陈奕迅", "周华健"]