根据对象数组中某个相同的属性,将相同属性对象合并为一个对象,从而得到新的数组

根据对象数组中某个相同的属性,将相同属性对象合并为一个对象,从而得到新的数组

let arr = [
    {
        timestamp: 1597593600000,
        total: 1892,
        '合川区': 1
    },
    {
        timestamp: 1597593600000,
        total: 1892,
        '长沙市': 13
    },
    {
        timestamp: 1597593600000,
        total: 1892,
        '常德市': 14
    },
    {
        timestamp: 1597680000000,
        total: 1892,
        '合川区': 1
    },
    {
        timestamp: 1597680000000,
        total: 1892,
        '长沙市': 10
    }
];
根据相同的timestamp,将对象合并,得到这样的格式:
let arr = [
    {
        timestamp: 1597593600000,
        total: 1892,
        '合川区': 1,
        '长沙市': 13,
        '常德市': 14
    },
    {
        timestamp: 1597680000000,
        total: 1892,
        '合川区': 1,
        '长沙市': 10
    }
];

上代码:
let endList = [];
_.values(_.groupBy(arr, 'timestamp')).forEach((itemList) => {
    let data = {};
    itemList.forEach(d => {
        data = Object.assign(data, d);
    });
    return endList.push(data);
});

console.log(endList);
打印出来就是所需格式,其中用的大多是Lodash里面的方法实现,
Lodash官网地址

Lodash 使用

npm i --save lodash

main.js

import _ from 'lodash'
Vue.prototype._ = _

在这里插入图片描述

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值