检索具有多个系列的Highcharts的JSON数据?

时间:2013-09-16 07:53:27

标签: javascript php json highcharts

我一直在查看大量示例,但我似乎无法获取我的代码来提取数据。该图表是空白的。

我有一个php文件,它提供以下内容:(date,value1,value2)

[
["2013-09-15 08:44:37",19.8,8.19],
["2013-09-15 08:47:37",18.4,7.81],
["2013-09-15 08:50:37",18.3,7.78],
["2013-09-15 08:53:37",18.1,7.77]
]

然后我有以下代码:

<!DOCTYPE html>
<head>
  <script src="js/jquery-1.10.2.min.js"></script>
  <script src="js/highcharts.js" type="text/javascript"></script>
  <script>
  var chart;
  $(document).ready(function() {
     var options = {
        chart: {
           renderTo: 'container',
           type: 'line',
        },
        title: {
        },
        xAxis: {
           type: 'datetime'
        },
        yAxis: {
        },
        series: [{
           name: 'val1',
           data: []
       }, {
           name: 'val2',
           data: []
        }]
     };
     $.getJSON('data_day.php', function(json) {
        val1 = [];
        val2 = [];
        $.each(json, function(key,value) {
        val1.push([value.time, value.val1]);
        val2.push([value.time, value.val2]);
        });

        options.series[0].data = val1;
        options.series[1].data = val2;
        chart = new Highcharts.Chart(options);
     });
  });
  </script>
</head>
<html>

我正在尝试用萤火虫来看看我哪里出错了。如果我把

console.log(key,value) 

在$ .each下我可以看到数据:

0 ["2013-09-15 08:50:37", 18.3, 7.78]
1 ["2013-09-15 08:53:37", 18.1, 7.77]
2 ["2013-09-15 08:56:37", 18.2, 7.8]

是否有问题
val1.push([value.time, value.val1]);

options.series[0].data = val1;

更新:将其更改为此,现在正在使用。

val1.push([value[0], value[1]]);
val2.push([value[0], value[2]]);

1 个答案:

答案 0 :(得分:1)

根据Pal的评论 - 改为:

val1.push([value[0], value[1]]);
val2.push([value[0], value[2]]);