如何将x轴和y轴值的系列数据输入行高图?

时间:2014-06-02 10:19:47

标签: php jquery highcharts

我必须在折线图中显示一些实验结果。我让它适用于静态数据,但我想让它变得动态。

所以我得到了:

我有折线图:

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

我想要这样的事情:http://jsfiddle.net/gh/get/jquery/1.7.1/highslide-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。

提前致谢。

1 个答案:

答案 0 :(得分:0)

如果要创建此类格式,则需要先重新构建它们。考虑这个例子:

<?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>

Sample Output

  

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