一、前言

reduce() 方法接收一个函数作为累加器,数组中的每个值(从左到右)开始缩减,最终计算为一个值。

reduce() 可以作为一个高阶函数,用于函数的 compose。

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

二、语法

arr.reduce(callback,initialValue)

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

三、实例解析intialValue参数

1、第一个例子:

var arr = [1, 2, 3, 4];
var sum = arr.reduce(function(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

2、第二个例子

var  arr = [1, 2, 3, 4];
var sum = arr.reduce(function(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是什么情况?

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

但是要是我们设置了初始值就不会报错,如下:

var  arr = [];
var sum = arr.reduce(function(prev, cur, index, arr) {
console.log(prev, cur, index);
return prev + cur;
},0)
console.log(arr, sum); // [] 0

所以一般来说,提供初始值更加安全。

四、reduce简单用法

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

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

五、reduce高级用法

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

let names = ['Alice', 'Bob', 'Tiff', 'Bruce', 'Alice'];

let nameNum = names.reduce((pre,cur)=>{
if(cur in pre){
pre[cur]++
}else{
pre[cur] = 1
}
return pre
},{})
console.log(nameNum); //{Alice: 2, Bob: 1, Tiff: 1, Bruce: 1}

(2)数组去重

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

(3)将二维数组转化为一维

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

(4)将多维数组转化为一维

let arr = [[0, 1], [2, 3], [4,[5,6,7]]]
const newArr = function(arr){
return arr.reduce((pre,cur)=>pre.concat(Array.isArray(cur)?newArr(cur):cur),[])
}
console.log(newArr(arr)); //[0, 1, 2, 3, 4, 5, 6, 7]

(5)对象里的属性求和

var result = [
{
subject: 'math',
score: 10
},
{
subject: 'chinese',
score: 20
},
{
subject: 'english',
score: 30
}
]; var sum = result.reduce(function(prev, cur) {
return cur.score + prev;
}, 0);
console.log(sum) //60

(6)将[1,3,1,4]转为数字1314

function addDigitValue(prev,curr,curIndex,array){
var exponent = (array.length -1) -curIndex;
var digitValue = curr*Math.pow(10,exponent);
return prev + digitValue;
}
var arr6 = [1,3,1,4];
var result7 = arr6.reduce(addDigitValue,0)
console.info('result7',result7)

最新文章

  1. git简易操作
  2. DOM常用方法总结
  3. MySQL触发器使用详解
  4. JVM-class文件完全解析-属性表集合
  5. 整除的尾数[HDU2099]
  6. 【脚本语言对比】BASH,PERL以及PYTHON
  7. Java邮件服务学习之三:邮箱服务客户端-Java Mail
  8. [selenium webdriver Java]检查元素是否存在
  9. HDU1395+快速幂
  10. java.lang.NullPointerException错误分析
  11. Using django model/authentication/authorization within Tornado
  12. 关于JSON.parse在ie6,ie7下未定义的issue
  13. 虔诚的墓主人(bzoj 1227)
  14. NC 创建表空间数据库
  15. vue实现一个简易Popover组件
  16. 自建Socket转发,使用远程桌面(mstsc)连接家中电脑
  17. [luogu P2234] [HNOI2002]营业额统计
  18. ubuntu14.04下开启ssh服务
  19. The Google File System——论文详解(转)
  20. AngularJS实战之ngAnimate插件实现轮播

热门文章

  1. Android 学习笔记之Bitmap位图虽触摸点移动
  2. 50.Node.js 连接 MySQL
  3. 39.C语言操作数据库
  4. windows下gopath设置
  5. mysql字符设置乱码问题
  6. ajax事件(五)
  7. DataGridView控件绑定数据源
  8. Android使用蓝牙连接adb调试App
  9. 1.3 Quick Start中 Step 3: Create a topic官网剖析(博主推荐)
  10. MyEclipse 2016 安装/破解