问答

js数组reduce方法求对象属性之和,为什么此时用箭头函数返回的是

作者:admin 2021-04-17 我要评论

1. js数组reduce方法求对象属性之和,为什么此时用箭头函数返回的是undefined 没有用箭头函数时: var result = [ { subject: 'math', score: 10 }, { subject: ...

在说正事之前,我要推荐一个福利:你还在原价购买阿里云、腾讯云、华为云服务器吗?那太亏啦!来这里,新购、升级、续费都打折,能够为您省60%的钱呢!2核4G企业级云服务器低至69元/年,点击进去看看吧>>>)

1. js数组reduce方法求对象属性之和,为什么此时用箭头函数返回的是undefined

没有用箭头函数时:

var result = [
    {
        subject: 'math',
        score: 10
    },
    {
        subject: 'chinese',
        score: 20
    },
    {
        subject: 'english',
        score: 30
    }
];

var sum = result.reduce(function(prev, cur) {
    return cur.score + prev;
}, 0);
console.log(sum) //60

我把函数改成箭头函数:

var result = [
    {
        subject: 'math',
        score: 10
    },
    {
        subject: 'chinese',
        score: 20
    },
    {
        subject: 'english',
        score: 30
    }
];

var sum = result.reduce((prev,cur) => {cur.score + prev},0)
console.log(sum) // undefined

2. 计算数组中每个元素出现的次数,这里给reduce方法赋initialValue的时候,给了一个空对象,这是导致最后的nameNum为一个对象的原因吗,这里的 pre[cur]++ 为什么会转化为 Alice:2 这对值的?

let names = ['Alice', 'Bob', 'Tiff', 'Bruce', 'Alice'];

let nameNum = names.reduce((pre,cur)=>{
  if(cur in pre){
    pre[cur]++
  }else{
    pre[cur] = 1 
  }
  return pre
},{})
console.log(nameNum); //{Alice: 2, Bob: 1, Tiff: 1, Bruce: 1}
###

你没有return

var sum = result.reduce((prev,cur) => {return cur.score + prev},0)

var sum = result.reduce((prev,cur) => cur.score + prev,0)

版权声明:本文转载自网络,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。本站转载出于传播更多优秀技术知识之目的,如有侵权请联系QQ/微信:153890879删除

相关文章
  • nginx响应速度很慢

    nginx响应速度很慢

  • 点击选中的多选框,会在已选那一栏显示

    点击选中的多选框,会在已选那一栏显示

  • PHP 多态的理解

    PHP 多态的理解

  • 关于C语言中static的问题

    关于C语言中static的问题

腾讯云代理商
海外云服务器