累加的实现:基于 Array.prototype.reduce()

一:简介

reduce() 方法对数组中的每个元素执行一个由您提供的reducer函数(升序执行),将其结果汇总为单个返回值。

二:语法

arr.reduce(callback(accumulator, currentValue, index, array), initialValue])

  1. cb回调函数 必填
  2. initialValue可选 :作为第一次调用 cb函数时的第一个参数的值

三:参数:

3.1:第一个参数:cb函数;

cb函数包含4个参数:

  1. accumulator:累计器累计回调的返回值; 它是上一次调用回调时返回的累积值,或initialValue;
  2. currentValue :数组中正在处理的元素;
  3. index :数组中正在处理的当前元素的索引;如果提供了initialValue,则起始索引号为0,否则从索引1起始
  4. array: 调用reduce()的数组;

3.2:第二个参数:initialValue初始值;

1. 作为第一次调用 callback函数时的第一个参数的值
2. 如果没有提供初始值,则将使用数组中的第一个元素

四:Demo示例;【可掠过上方直接阅读】

4.1 基础用法[ 数组元素为基础数据类型:number\string];

let arr = [1, 2, 3, 4, 5];
const cb = (accumulator, currentValue, index, arr) => {
    return accumulator + currentValue
}
let total =  arr.reduce(cb,2);
console.log(total,44444)   // 17    
// 1 . 此处初始值2,实际意义 2+1+2+3+4+5 = 17
// 2 . cb首次运行 accumulator =2,index =0,currentValue=arr[0];
// 3 . 假设没有初始值2 ,则accumulator =arr[0],index =1,currentValue=arr[1];

4.2 进阶用法[ 数组元素为Object];

4.2.1 javaScript版本

// index.js
var total;
var arr = [{ num: 1 }, { num: 1 }, { num: 1 }, { num: 1 }, { num: 6 }];
var cb = function (accumulator, currentValue, index, arr) {
    if (index === arr.length - 1) {
        total = accumulator.num + currentValue.num;
    }
    return {
        num: accumulator.num + currentValue.num
    };
};
var accumulation = function () {
    console.log(arr.reduce(cb), '总数', total);
};
accumulation();

4.2.1 TypeScript版本

// 自定义类型
interface customClass {
    num: number
}
// 储存累加值;
let totalNum: number;
const arr: Array<customClass> = [{ num: 1 }, { num: 1 }, { num: 1 }, { num: 1 }, { num: 6 }];
const cb = (accumulator: customClass, currentValue: customClass, index: number, arr: Array<customClass>): customClass => {
    // cb返回值必须是customClass数据类型;因为返回值会被当做下一次循环,执行cb函数的第一个参数使用;
    if (index === arr.length - 1) {
        // 判定是最后一次循环执行cb函数后将总值保存到totalNum变量;
        totalNum = accumulator.num + currentValue.num
    }
    // 返回值类型必须符合customClass数据类型;
    return {
        num: accumulator.num + currentValue.num
    };
}

const accumulation = ():void => {
    console.log('reduce执行结果=' + JSON.stringify(arr.reduce(cb)), 'totalNum=' + totalNum) //  { num: 10 } 总数 10
}
accumulation();
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值