Google图表未显示,未显示任何错误

时间:2013-10-16 09:58:45

标签: javascript json web-services google-visualization

我正在尝试使用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数组中硬编码测试数据,图表会显示......:/

1 个答案:

答案 0 :(得分:0)

确定我的代码没有问题。 图表在jquery手风琴中,这导致了问题。 要解决这个问题,只有在手风琴已经“创建”,即

之后才能渲染图表
$('div').accordion();

已被召集。 然后他们应该正确呈现。