js数组的reduce方法的使用

reduce常用来做累计,大部分业务场景下,reduce可以实现的功能通过forEach、map等遍历也可以实现。

1、语法摘要
array.reduce(callback(accumulator, currentValue[, index[, array]])[, initialValue])
  • callback
    执行数组中每个值 (如果没有提供 initialValue则第一个值除外)的函数,包含四个参数:

    • accumulator
      累计器累计回调的返回值; 它是上一次调用回调时返回的累积值,或initialValue(见于下方)。

    • currentValue
      数组中正在处理的元素。

    • index 可选
      数组中正在处理的当前元素的索引。 如果提供了initialValue,则起始索引号为0,否则从索引1起始。

    • array可选
      调用reduce()的数组

  • initialValue可选
    作为第一次调用 callback函数时的第一个参数的值。 如果没有提供初始值,则将使用数组中的第一个元素。 在没有初始值的空数组上调用 reduce 将报错。

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

2、实例解析
  • 求和

    let arr = [
        {
          value: 10,
          id: 1
        },
        {
          value: 20,
          id: 2
        },
        {
          value: 30,
          id: 3
        },
        {
          value: 40,
          id: 4
        },
        {
          value: 50,
          id: 5
        },
    
      ]
    
      let yy = arr.reduce((sum, current) => {
        return sum + current.id
      }, 0)
      console.log(yy); // 15 为所有id的和
    
  • 把数组转化为对象映射,某些业务场景下可能需要

    const data = [
        {id: 100, name: '张三'},
        {id: 200, name: '李四'},
        {id: 300, name: '王五'}
      ];
    
      const result = data.reduce((acc, el, i) => {
        acc[el.name] = el.id;
        return acc;
      }, {});
    
      console.log(result) //{张三: 100, 李四: 200, 王五: 300}
    
  • 数组去重

    let names = [
        '周杰伦',
        '孙燕姿',
        '陈奕迅',
        '周华健',
        '孙燕姿',
        '周华健',
        '周杰伦',
      ]
      let newNames = names.reduce((acc, el, index) => {
        if (!acc.includes(el)) {
          acc.push(el);
          return acc;
        } else {
          return acc;
        }
      }, [])
      console.log(newNames); // ["周杰伦", "孙燕姿", "陈奕迅", "周华健"]
    
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值