如何在直线高图中提供具有x轴和y轴值的系列数据


How to feed series data that has x axis and y axis values in line highcharts?

我必须用折线图展示一些实验结果。我让它为静态数据工作,但我想让它动态。

所以我得到的是:

我有一个折线图:

       var options = {
            chart: {
                renderTo: 'container',
                        type: 'line',
                            },
                    series: [{}]
        }

我想要这样的东西:http://jsfiddle.net/gh/get/jquery/1.7.1/hililide-software/highcharts.com/tree/master/samples/highcharts/series/data-array-of-arrays/

我正在努力使这些数据:

            data: [
            [0, 29.9], 
            [1, 71.5], 
            [3, 106.4]
        ]

在PHP端,并发送它jquery,并馈送到我的折线图。我知道JSON编码,但是我应该如何在php中创建数组呢?我该如何对其进行编码并将其交给jquery并提供折线图呢?

这是目前为止的工作与静态数据:

             var arr = [[0, 15], [10, 50], [20, 56.5], [30, 46.5], [40, 22.1],
                            [50, 2.5], [60, 27.7], [70, 55.7], [80, 76.5]];
                options.series[0].name = 'Occlusion';
                options.series[0].data = arr;
    var l = new Highcharts.Chart(options);
    });

但是我希望arr来自php。

提前感谢。

如果您想要创建这样的格式,您需要首先重构它们。考虑这个例子:

<?php
// lets say you have a raw data like this
$php_values = array(
    array(0, 15),
    array(10, 50),
    array(20, 56.5),
    array(30, 46.5),
    array(40, 22.1),
    array(50, 2.5),
    array(60, 27.7),
    array(70, 55.7),
    array(80, 76.5),
);
$temp = array();
// format each array
foreach($php_values as $key => $value) {
    $temp[] = '['.implode(',', $value).']';
}
// then format the whole array
$formatted_values = '['.implode(',', $temp).']';
?>
<script type="text/javascript">
    var values = <?php echo $formatted_values; ?>;
    console.log(values);
</script>

编辑:正如@SebastianBochan指出的, $formatted_values = json_encode($php_array) 的工作方式相同(可能是最好和最干净的方式)