es6中reduce()方法和reduceRight()方法

Posted sexintercourse

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了es6中reduce()方法和reduceRight()方法相关的知识,希望对你有一定的参考价值。

es6中reduce()方法
从左往右开始

参数:
prev:它是上一次调用回调时返回的结果,每次调用的结果都会给prev

cur:当前的元素

index:当前的索引

arr:循环的数组

返回值:
函数累计处理的结果

demo:
求数组的和。

var a = [1,2,3,4,5,6,7,8,9,10]

var str = a.reduce(function(prev,cur,index,arr){
return prev + cur ;
})
str // 55;
求阶乘

var a = [1,2,3,4,5,6,7,8,9,10]

var str = a.reduce(function(prev,cur,index,arr){
return prev * cur ;
})

str //3628800
求幂

新增的一个运算符 

A ** B;

var a = [2,3,4];

var str = a.reduce(function(prev,cur,index,arr){
return prev ** cur ;
})

str // 4096
 将二维数组转换成一维

var a= [[0,1],[2,3],[4,5],[6,7],[8,9]];

var str = a.reduce(function(prev,cur){
return prev.concat(cur)
})

str //(10) [0,1, 2, 3, 4, 5, 6, 7, 8, 9]
 数组去重

var arr = [1,2,1,2,3,5,4,5,3,4,4,4,4];
var str = arr.sort().reduce((prev, cur)=>{
if(prev.length===0 || prev[prev.length-1]!==cur){
prev.push(cur);
}
return prev;
}, []);
str // (5) [1, 2, 3, 4, 5]
 

es6中reduceRight()方法
从右往左开始

参数和上面是一样。

结果都是一样的我就不写代码了

 
————————————————
版权声明:本文为CSDN博主「阿泽啊」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_41702660/article/details/81949459

以上是关于es6中reduce()方法和reduceRight()方法的主要内容,如果未能解决你的问题,请参考以下文章

ES6新特性:map和reduce

ES6高级函数Array.reduce()和Object.assign()

es6 reduce方法是遍历数组吗

ES6 之reduce的高级技巧

es6数组的方法

ES6中reduce的计算过程