Бих искал да използвам jqPlot, използвайки данни от страната на сървъра, идващи в JSON, както е описано в този пример: http://www.jqplot.com/tests/data-renderers.php
Моят код е почти същият като примера:
function myGraph(jsonurl) {
var ajaxDataRenderer = function(url, plot, options) {
var ret = null;
$.ajax({
// have to use synchronous here, else the function
// will return before the data is fetched
async: false,
url: url,
dataType:"json",
success: function(data) {
ret=data;
console.warn(data);
}
});
return ret;
};
var plot1 = $.jqplot('chartdiv', jsonurl, {
title: 'myTitle',
dataRenderer: ajaxDataRenderer,
dataRendererOptions: { unusedOptionalUrl: jsonurl },
series: [{
label: 'myLabel',
neighborThreshold: -1
}],
axes: {
xaxis: {
renderer: $.jqplot.DateAxisRenderer,
// min:'August 1, 2010 16:00:00',
tickInterval: '2 months',
tickOptions:{formatString:'%Y-%m-%d.%H:%M:%S'}
},
yaxis: {
tickOptions:{formatString:'$%.2f'}
}
},
});
От страната на сървъра използвам PHP (и Yii). Уеб страницата връща масив, който е кодиран в JSON с помощта на CJSON::encode($resultArray);
(тази функция на Yii, преминала през функцията за кодиране на PHP JSON). Резултатите от PHP скрипта изглеждат така:
{"2011-04-25 14:46:40":2,"2011-04-26 14:46:40":3,"2011-04-27 14:46:40":5}
Заявката на Ajax от страна на клиента разреши нещо подобно (изход от console.info();
)
Object { 2011-04-25 14:46:40=2, 2011-04-26 14:46:40=3, ...}
Вероятно jqPlot очаква следния формат:
[[["2011-04-25 14:46:40":0],["2011-04-26 14:46:40",3],["2011-04-27 14:46:40",0]]]
През цялото време получавам error uncaught exception: [object Object]
Какво не е наред? Има ли начин да конвертирате обекта за в типичната форма на масив?
Благодаря ти