⼆维数组各⾏求和_Js数组系列reduce()⽅法详解及使⽤技
巧
前⾔
ECMAScript5 新增的归并⽅法reduce():
reduce() ⽅法接收⼀个函数作为累加器(迭代器),数组中的每个值(从左到右)开始缩减,最终计算为⼀个值。
reduce() 可以作为⼀个⾼阶函数,⽤于函数的 compose。
reduce()⽅法可以搞定的东西,for循环,或者forEach⽅法有时候也可以搞定,成功的道路有很多条,我们先看看reduce⽅法这⼀条。
语法
reducer 函数接收4个参数:
1. Accumulator (acc) (累计器)
2. Current Value (cur) (当前值)
3. Current Index (idx) (当前索引)
4. Source Array (src) (源数组)
返回最后⼀个值,就是函数累计处理的结果。
实例解析intialValue参数
⽰例⼀:
var arr = [1, 2, 3, 4]
var sum = duce(function(prev, cur, index, arr) {
console.log(prev, cur, index)
return prev + cur
})
console.log(arr, sum)
callback prev cur value
first123
second336
third6410
⽰例⼆:
var arr = [1, 2, 3, 4];
var sum = duce(function(prev, cur, index, arr) {
console.log(prev, cur, index);
return prev + cur;
},0) //注意这设置的初始值
console.log(arr, sum);
callback prev cur value
first011
second123
third336
fourth6410
这个例⼦index是从0开始的,第⼀次的prev的值是我们设置的初始值0,数组长度是4,reduce函数循环4次。
结论:如果没有提供initialValue,reduce 会从索引1的地⽅开始执⾏ callback ⽅法,跳过第⼀个索引。如果提供initialValue,从索引0开始。
注意:若数组为空,运⽤reduce会报错
var arr = [];
var sum = duce(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 = duce(function(prev, cur, index, arr) {
console.log(prev, cur, index);
return prev + cur;
},0)
console.log(arr, sum); // [] 0
结论:所以⼀般来说,提供初始值更加安全。
四、reduce简单⽤法
当然最简单的就是我们常⽤的数组求和,求乘积了。
reduce⾼级⽤法
reduce除了⼀些常规处理数组、求和、乘积的简单⽤法,还有以下⾼级⽤法,这些⽤法不仅在算法中能为我们操作数据便利,也利于我们完成⼯作业务中的数据封装。
计算数组中每个元素出现的次数
let names = ['cavin', 'Jack', 'Amy', 'Tom', 'cavin'];
let nameNum = duce((pre,cur)=>{
if(cur in pre){
pre[cur]++
}else{
pre[cur] = 1
}
return pre
},{})
console.log(nameNum); //{cavin: 2, Jack: 1, Amy: 1, Tom: 1}
(2)数组去重
let arr = [1,2,3,4,4,1]
let newArr = duce((pre,cur)=>{
if(!pre.includes(cur)){
at(cur)
}else{
return pre
}
},[])
console.log(newArr);// [1, 2, 3, 4]
(3)⼆维数组扁平化化为⼀维
let arr = [[0, 1], [2, 3], [4, 5]]
let newArr = duce((pre,cur)=>{
at(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){
js数组方法总结duce((pre,cur)=&at(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 = duce(function(prev, cur) {
return cur.score + prev;
}, 0);
console.log(sum) //60
(6)将[1,3,1,4]转为数字1314
function changeDigitValue(prev,curr,curIndex,array){
var exponent = (array.length -1) -curIndex;
var digitValue = curr*Math.pow(10,exponent);
return prev + digitValue;
}
var arr = [1,3,1,4];
var ret = duce(changeDigitValue,0)
console.info('ret',ret)
总结
reduce()⽅法确实能为我们在⼀些算法中带来操作数据便利和利于我们完成⼯作业务中的数据封装。如果⽂中有错误的地⽅,希望⼤家指出,共同进步。
您的⼩⼩关注,是我的最⼤动⼒!
参考⽂档
《JavaScript⾼级程序设计》
MDN中⽂⽹
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论