2

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

我有一个 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]]);
4

1 回答 1

1

根据 Pal 的评论 - 将其更改为:

val1.push([value[0], value[1]]);
val2.push([value[0], value[2]]);
于 2013-09-16T08:22:13.300 回答