Array.reduce()理解

参考:MDN https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/Reduce

Array.reduce(function(accumulator, currentValue, currentIndex, array), initialValue)
属性解释
accumulator累加器累加回调的返回值;它是先前在回调的最后一次调用中返回的累计值,如果提供的话,则为initialValue(见下文)。
currentValue当前元素在数组中处理。
currentIndex数组中正在处理的当前元素的索引。如果提供了initialValue,则从索引0开始,否则从索引1开始。
array调用 reduce 的数组
此例子不带initialValue 每一步的执行结果如下

[2,3,4,5].reduce(function(accumulator, currentValue, currentIndex, array){
	return accumulator + currentValue;
}, initialValue);


[2,3,4,5].reduce(function(2,3,1,[2,3,4,5]){
	return 2+ 3; //5
});


[2,3,4,5].reduce(function(2,3,2,[2,3,4,5]){
	return 2+ 3; //5
});



[2,3,4,5].reduce(function(5,4,3,[2,3,4,5]){
	return 5+4; //9
});

[2,3,4,5].reduce(function(9,5,4,[2,3,4,5]){
	return 9+5; //14
});
//所以最后结果就是14

带参数initialValue 每一步的执行结果如下

参数initialValue直接为开始时accumulator的值


[4,5,6,7].reduce(function(accumulator, currentValue, currentIndex, array){
	return accumulator + currentValue;
}, initialValue);


[4,5,6,7].reduce(function(10,4,1,[4,5,6,7]){
	return 10 + 4; //14
},10);


[4,5,6,7].reduce(function(14,5,2,[4,5,6,7]){
	return 14 + 5; //19
},10);


[4,5,6,7].reduce(function(19,5,3,[4,5,6,7]){
	return 19 + 5; //24
},10);


[4,5,6,7].reduce(function(24,6,4,[4,5,6,7]){
	return 24 + 6; //30
},10);


[4,5,6,7].reduce(function(30,7,5,[4,5,6,7]){
	return 30 + 7; //37
},10);
//所以最后结果就是37
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值