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

Neoo1984
  • 53

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}
回复
阅读 611
1 个回答
✓ 已被采纳

你没有return

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

var sum = result.reduce((prev,cur) => cur.score + prev,0)
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
你知道吗?

宣传栏