我正在尝试使用API绘制Google柱形图。数据来自webservice作为JSON字符串,我解析然后进行操作以添加数据,然后显示图表,就像这样。
var jsond = JSON.parse(response.d);
var data = null;
data = new google.visualization.DataTable();
for (var i = 0; i < jsond["cols"].length; i++) {
data.addColumn((jsond["cols"][i].type == 'number' ? 'number' : 'string'), null, jsond["cols"][i].id);
}
data.addRows(jsond["rows"].length);
for (var i = 0; i < jsond["rows"].length; i++) {
data.setCell(i, 0, "'" + jsond["rows"][i].finmonth.toString() + "'");
data.setCell(i, 1, parseFloat(jsond["rows"][i].Target));
data.setCell(i, 2, parseFloat(jsond["rows"][i].Proposal));
data.setCell(i, 3, parseFloat(jsond["rows"][i].ContractTotal));
data.setCell(i, 4, parseFloat(jsond["rows"][i].Budget));
data.setCell(i, 5, parseFloat(jsond["rows"][i].flag));
}
var options = {
title: 'The road thus far',
vAxis: { title: "Totals" },
hAxis: { title: "Financial Month" }
};
var chart = new google.visualization.ColumnChart(document.getElementById('chart_div'));
chart.draw(data, options);
现在的问题是它接受数据并且没有返回的错误。我使用data.toJSON()
将数据加载到数据表后检查了数据,并且它与google规定数据的方式相匹配。请参阅下面的数据,请记住我在下面的示例中只添加了1个数据行,有12个标准行。
{"cols":[{"id":"finmonth","label":"","pattern":"","type":"string"},
{"id":"Target","label":"","pattern":"","type":"number"},
{"id":"Proposal","label":"","pattern":"","type":"number"},
{"id":"ContractTotal","label":"","pattern":"","type":"number"},
{"id":"Budget","label":"","pattern":"","type":"number"},
{"id":"flag","label":"","pattern":"","type":"number"}],
"rows":[{"c":[{"v":"'2013/1'","f":null},{"v":0,"f":null},{"v":37,"f":null},{"v":4696,"f":null},{"v":4733,"f":null},{"v":0,"f":null}]}],
"p":null}
那我错过了什么?因为如果我在javascript数组中硬编码测试数据,图表会显示......:/
答案 0 :(得分:0)
确定我的代码没有问题。 图表在jquery手风琴中,这导致了问题。 要解决这个问题,只有在手风琴已经“创建”,即
之后才能渲染图表$('div').accordion();
已被召集。 然后他们应该正确呈现。