我正在尝试使用动态JSON渲染jqplot小部件,但我找不到如何操作。
我看到的唯一示例包括从文件中读取JSON,但我想将JSON用作String,例如:
{"oranges":"10","apples":"20","bananas":"6"}
任何想法?
答案 0 :(得分:3)
您问题中的数据不是字符串,而是javascript对象字面值。
如果您有橙子,苹果和香蕉,您可能想要绘制条形图;您需要从对象中提取标签和值,然后绘制图表:
var chart_data = {"oranges":"10", "apples":"20", "bananas":"6"};
var line1 = [];
for (var prop_name in chart_data) {
line1.push([prop_name, chart_data[prop_name]])
}
// line1 should be [["oranges", 10], ["apples", 20], ["bananas", 6]]
// code snippet from http://www.jqplot.com/tests/rotated-tick-labels.php
// please change it as you need
var plot1 = $.jqplot('chart1', [line1], {
title: 'Fruits',
series: [{renderer:$.jqplot.BarRenderer}],
axesDefaults: {
tickRenderer: $.jqplot.CanvasAxisTickRenderer
},
axes: {
xaxis: {
renderer: $.jqplot.CategoryAxisRenderer
}
}
});
答案 1 :(得分:0)
$.getJSON(url,"json").success(function(data) {
var line1 = [];
var content = $.parseJSON( data);
$.each(content, function(index, item) {
line1.push([item.date, item.value])
});
var plot1 = $.jqplot("chart1",[line1], { .....
这是一个很好的例子,如何将json数据转换为jqplot可以使用的数组......