我必须在折线图中显示一些实验结果。我让它适用于静态数据,但我想让它变得动态。
所以我得到了:
我有折线图:
var options = {
chart: {
renderTo: 'container',
type: 'line',
},
series: [{}]
}
我正在努力制作这些数据:
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。
提前致谢。
答案 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>
编辑:正如@SebastianBochan指出的那样,
$formatted_values = json_encode($php_array)
的工作方式相同(可能是最好也是最干净的方式)