我目前正在尝试使用morris.js来创建图表。我有一个JSON对象,需要让它看起来像另一个。 Morris.js需要一个看起来像这样的数组
var day_data = [
{"period": "2012-10-01", "licensed": 3407, "sorned": 660},
{"period": "2012-09-17", "licensed": 3171, "sorned": 660},
{"period": "2012-09-16", "licensed": 3171, "sorned": 676},
{"period": "2012-09-15", "licensed": 3201, "sorned": 656},
{"period": "2012-09-10", "licensed": 3215, "sorned": 622}
];
如果对象显得混乱,这里是链接。它应该是其网站http://oesmith.github.com/morris.js/上第一个图表数据的缩短版本 。它非常简单,周期是x坐标,许可和附加是相应行的y坐标。
这是我给出的数据
var trendline = {"command":[
{"keyValuePairs":["2012-08-10 22:00:00|1884978","2012-08-10 21:00:00|3135378","2012-08-10 18:00:00|2541438","2012-08-09 20:00:00|647082","2012-08-10 19:00:00|3194772","2012-08-09 16:00:00|2782140","2012-08-10 20:00:00|3669924"],
"keyword":"Obama"},
{"keyValuePairs":["2012-08-10 22:00:00|1884978","2012-08-10 21:00:00|3135378","2012-08-10 18:00:00|2541438","2012-08-09 20:00:00|647082","2012-08-10 19:00:00|3194772","2012-08-09 16:00:00|2782140","2012-08-10 20:00:00|3669924"],
"keyword":"Romney"}]}
我需要从keyValuePairs中提取所有数据并将其与其关键字相关联,因此看起来像第一个数组
{"period": "2012-10-01", "Obama": 1884978, "Romney": 1884978},
...
...
我知道从trendline JSON对象获取数据但我不知道如何构造morris.js插件可以使用的新JSON对象。更具体地说,我不知道如何使用变量创建JSON对象。
trendline.dog = [cat];
将创建一个json对象,并将field dog设置为值cat。但是,我需要获取每个关键字(奥巴马,罗姆尼......等)并有一个与之关联的字段并为其设置值。由于我不知道字段的数量或它们的名称,我不知道如何创建这个对象。
假设我不能改变我给出数据的方式,因为我不写那部分。另外,我可以只给出两个关键字(奥巴马/罗姆尼),就像我的例子一样,或者我可以为y值给出任意数量的关键字。
很抱歉。任何帮助,将不胜感激。谢谢你的时间。
答案 0 :(得分:1)
这是你的圣诞礼物。
<script type="text/javascript">
var trendline =
{
"command": [
{
"keyValuePairs":
[
"2012-08-10 22:00:00|1884978",
"2012-08-10 21:00:00|3135378",
"2012-08-10 18:00:00|2541438",
"2012-08-09 20:00:00|647082",
"2012-08-10 19:00:00|3194772",
"2012-08-09 16:00:00|2782140",
"2012-08-10 20:00:00|3669924"
],
"keyword": "Obama"
},
{
"keyValuePairs":
[
"2012-08-10 22:00:00|1884978",
"2012-08-10 21:00:00|3135378",
"2012-08-10 18:00:00|2541438",
"2012-08-09 20:00:00|647082",
"2012-08-10 19:00:00|3194772",
"2012-08-09 16:00:00|2782140",
"2012-08-10 20:00:00|3669924"
],
"keyword": "Romney"
}]
}
var cmd = trendline.command,
day_data = [],
split,
date,
num,
obj;
//
for (var i = 0; i < cmd.length; i++) {
//
if (i == 1) { break; };
//
for (var ii = 0; ii < cmd[i].keyValuePairs.length; ii++) {
//debugger
split = cmd[i].keyValuePairs[ii].split('|');
date = split[0].substring(0, split[0].indexOf(' '));
num = split[1];
obj = {};
obj['period'] = date;
//Can 1
obj[cmd[i].keyword] = num;
//
split = cmd[i + 1].keyValuePairs[ii].split('|');
num = split[1];
//Can 2
obj[cmd[i + 1].keyword] = num;
//
day_data.push(obj);
};
};