Highcharts无法使用装有ajax的数组进行渲染

时间:2013-11-10 13:24:43

标签: javascript php ajax arrays highcharts

我刚刚开始使用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绘制没有数据的图形,但是当我使用“预填充”数组(就像我注释掉的那个)时,它工作正常。

2 个答案:

答案 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 +')')