V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
V2EX 提问指南
renmu123
V2EX  ›  问与答

问一个有关 JS 数据的问题

  •  
  •   renmu123 · 2019-04-21 15:04:10 +08:00 via Android · 1777 次点击
    这是一个创建于 2062 天前的主题,其中的信息可能已经有所发展或是发生改变。

    新手提问一个有关 JS 数据分类问题

    data = [{area: 'Shanghai', num:1}, {area: 'Beijing', num: 1}, {area: 'Shanghai', num:5}]
    
    
    
    newData = [{area: 'Shanghai', num:6}, {area: 'Beijing', num:1}]
    

    一个[]里面是多个{},对象里有 area,num。

    想要这样的效果,如果 area 相同,那么 num 就相加

    5 条回复    2019-04-21 17:59:46 +08:00
    Mexion
        1
    Mexion  
       2019-04-21 15:08:14 +08:00 via Android
    遍历
    Septembers
        2
    Septembers  
       2019-04-21 15:32:07 +08:00   ❤️ 3
    data.concat(newData).reduce((prev, next) => (prev[next.area] = (prev[next.area] || 0) + next.num, prev), {})
    ayase252
        3
    ayase252  
       2019-04-21 15:33:14 +08:00
    reduce 成一个{area: value}的对象,然后用 Object.key 遍历中间对象展开成想要的结果
    qiayue
        4
    qiayue  
       2019-04-21 16:55:40 +08:00
    中间增加一步,先得到中间结果
    {'Shanghai':6, 'Beijing':1}
    之后再展开上面的中间结果为
    [{area: 'Shanghai', num:6}, {area: 'Beijing', num:1}]
    Danswerme
        5
    Danswerme  
       2019-04-21 17:59:46 +08:00 via Android
    let obj = {};
    data.forEach(i => {
    if (obj.hasOwnProperty(i.area)) {
    obj[i.area] += i.num;
    } else {
    obj[i.area] = i.num;
    }
    });
    const newData = [];
    Object.keys(obj).forEach(key => {
    newData.push({
    area: key,
    num: obj[key]
    });
    });
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2267 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 15:53 · PVG 23:53 · LAX 07:53 · JFK 10:53
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.