如何在Javascript中将对象数组转换为关联数组对象

时间:2018-11-01 19:49:06

标签: javascript arrays dictionary object chart.js

我正在从系统接收以下结构。我试图利用chartjs将其弯曲为特定图形所需的形式。给定JSON数据结构…对象中的对象数组:

{
"chart": [
    {
        "date": "2018-10-29",
        "done": 3,
        "todo": 10

    },
    {
        "date": "2018-10-30",
        "done": 4,
        "todo": 7
    },
    {
        "date": "2018-10-31",
        "done": 5,
        "todo": 12
    }
]

}

我需要所需的JSON数据结构...一个数组对象(在一个数组中,在一个对象中)

{
"chart": [{
    "date": [
        "2018-10-29",
        "2018-10-29",
        "2018-10-31"
    ],
    "done": [
        3,
        4,
        5
    ],
    "todo": [
        10,
        7,
        12
    ]
}]

}

我尝试使用.map函数,但似乎没有正确的map-fu。

3 个答案:

答案 0 :(得分:2)

您可以获取一个对象,并在单个数组中获取所有带有这些值的键。

var data = { chart: [{ date: "2018-10-29", done: 3, todo: 10 }, { date: "2018-10-30", done: 4, todo: 7 }, { date: "2018-10-31", done: 5, todo: 12 }] },
    result = { chart: data.chart.reduce((r, o) => {
            Object.entries(o).forEach(([k, v]) => (r[k] = r[k] || []).push(v));
            return r;
        }, {})
    };
    
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }

答案 1 :(得分:1)

使用reduce怎么办?

const output = input.reduce((acc, curr) => ({
  date: acc.date.concat(curr.date),
  done: acc.done.concat(curr.done),
  todo: acc.todo.concat(curr.todo),
}), { date: [], done: [], todo: [] });

const chartData = {
  chart: [output],
};

reduce的参考在这里:https://developer.mozilla.org/fr/docs/Web/JavaScript/Reference/Objets_globaux/Array/reduce

答案 2 :(得分:0)

这是一个非常明确的解决方案。可能会有一些错误的Javascript解决方案;当然,您可以进行多个.map调用,但这会降低效率。

// Variables
var dates = [];
var doneValues = [];
var todoValues = [];

// Loop through the original data once, collect the data.
originalJSON.forEach(function(data) {
  dates.push(data["date"]);
  doneValues .push(data["done"]);
  todoValues .push(data["todo"]);
});

// Put it all together.
return {"chart": [{"date": dates, "done": doneValues , "todo": todoValues}]};

修改它以满足您的需求。