我刚刚开始使用Highcharts,但已经遇到了问题。 我想用Ajax调用中的数据填充我的图表,但它只显示一个空白图表。
首先,我想告诉您如何获取数据:
<?php
require_once("mysql_config.php");
$query = "SELECT temp FROM daten ORDER BY daten.id DESC LIMIT 0,6";
$answer = mysqli_query($mysqli,$query);
$row;
while($row = $answer->fetch_array()){
echo $row['temp'] . ",";
}
?>
输出结果如下: -20,0,0,7,0,0,100
我的AJAX功能:
function ajax(website, element, callback) {
var http = null;
var http = new XMLHttpRequest();
var url = website;
if(http!=null){
http.open("POST",url,true);
http.onreadystatechange = function(){
if(http.readyState == 4){
var text = http.responseText;
callback(text, element);
}
}//Ende readychange
http.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
http.send();
}//Ende if(http2!=null)
}//Ende Funktion
回调是我的create_chart函数
function create_chart(rawdata, element){
newdata = rawdata.split(",");
//var newdata = [-20,0,0,7,0,0,100];
var chart = new Highcharts.Chart({
chart: {
type: 'line',
renderTo: 'test'
},
title: {
text: 'Testchart'
},
subtitle:{
text: 'Subtitle'
},
xAxis: {
categories: ['A','B','C','D','E','F','G']
},
yAxis: {
title: {
text: 'This is it'
}
},
series: [{
name: "Test",
data: newdata
}]
});
}
问题是,它只使用ajax绘制没有数据的图形,但是当我使用“预填充”数组(就像我注释掉的那个)时,它工作正常。
答案 0 :(得分:1)
newdata
是一个字符串,当你拆分它时,它的碎片就是字符串。
“ - 20,0,0,7,0,0,100”.split(“,”)= [“ - 20”,“0”,“0”,“7”,“0”,“0” , “100”]
Highcharts需要数字,因此在拆分后,将parseInt
分成数字:
var rawdata = "-20,0,0,7,0,0,100";
var strdata = rawdata.split(",");
var newdata = []
for (var i = 0; i < strdata.length; i++)
{
newdata.push(parseInt(strdata[i]));
}
小提琴here。
答案 1 :(得分:0)
检查通过ajax将数据类型作为对象的响应。因为highcharts可以使用它,所以响应的数据类型为object。
如果它以字符串形式返回,则使用将其转换为对象 eval('('+ response +')')