es6中reduce()方法和reduceRight()方法
阿新 • • 發佈:2019-01-12
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()方法
從右往左開始
引數和上面是一樣。
結果都是一樣的我就不寫程式碼了