繁体   English   中英

使用JSON加载数据的canvasJS RangeArea图表

[英]Loading data with JSON for canvasJS RangeArea Chart

我正在尝试使用CanvasJS和PHP创建范围图,以从数据库中加载数据。

我创建了php,它从数据库返回了值。 这是PHP:

<?php
header('Content-Type: application/json');
$con = mysqli_connect("127.0.0.1","root","pwd1","db");
// Check connection
if (mysqli_connect_errno($con))
{
    echo "Failed to connect to DataBase: " . mysqli_connect_error();
}else
{
     $data_points = array();
     $result = mysqli_query($con, "select (CalYear+1) as CalYear, concat('[',REPLACE(Year1PercWC,',','.'),',',REPLACE(Year1PercBC,',','.'),']') as ResultSet, concat('Sessies: ',calyear) as Help FROM table where cat='1' and (CalYear+1)<year(now())");
    while($row = mysqli_fetch_array($result))
    {        
        $point = array("x" => $row['CalYear'] , "y" => $row['ResultSet'],"name" => $row['Help']);
         array_push($data_points, $point);        
    }
    echo json_encode($data_points);
}
mysqli_close($con);

?>

结果:

[{“ x”:“ 2007”,“ y”:“ [35.94,35.94]”,“ name”:“ Sessies:2006”},{“ x”:“ 2008”,“ y”:“ [27.67, 27.67]“,” name“:” Sessies:2007“},...,...]

问题是x和y值(=字符串值)中的引号。 CanvasJS仅使用数字来创建图形。 所以输出应该像这样:

[{“ x”:2007,“ y”:[35.94,35.94],“ name”:“ Sessies 2006”},{“ x”:2008,“ y”:[27.67,27.67],“ name”:“ Sessies 2007“},...,...]

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
    <title></title>
    <script type="text/javascript" src="jquery-1.11.2.min.js"></script>   
    <script type="text/javascript" src="jquery.canvasjs.min.js"></script> 
    <script type="text/javascript">
         $(document).ready(function () {
            $.getJSON("TestGraf.php", function (result) {
                var chart = new CanvasJS.Chart("chartContainer", {
                    axisX: { 
                        intervalType: "number", 
                        title: "Year", 
                        interval: 1,
                        valueFormatString: "#"
                    }, 
                    data: [
                        {
                            type: "rangeArea",
                            dataPoints: result
[{"x":2007,"y":[35.94,35.94],"name":"Sessies 2006"},{"x":2008,"y":[27.67,27.67],"name":"Sessies 2007"}] -- This is working fine
                        }
                    ]
                });
                chart.render();
            }); 
        });
    </script>
</head>
<body>
    <div id="chartContainer" style="width: 800px; height: 380px;"></div>
</body>
</html>

我确定必须有一种方法来适应我的php,以便x和y以数字而不是字符串的形式传递,但是我真的是php的新手(有史以来第一次),并且找不到解决方案,尤其是对于第二部分(y)。

谁能告诉我要对php和/或html文件进行哪些修改?

谢谢,

这可能应该为您工作:

json_encode($arr, JSON_NUMERIC_CHECK);

我的回答可能为时已晚,但像Alex回答的那样,您应该使用echo json_encode($ data_points,JSON_NUMERIC_CHECK);

数字检查是一个选项。 参见http://php.net/manual/en/json.constants.php

但是,似乎更需要了解范围图的工作原理。 范围面积图具有X和2 Y值。 需要2个Y值来绘制范围。 如果仅在浏览器中转到testgraf.php文件,则JSON结果应为:[{x:somevalue,y:[low_value,high_value]}]

您可能必须更改sql语句才能获得另一个y值。 您可以执行此操作。 无论如何,这是您应该为您的php代码执行的操作:

更改

$point = array("x" => $row['CalYear'] , "y" => $row['ResultSet'],"name" => $row['Help']);

至:

$point = array("x" => $row['CalYear'] , "y" => $row['ResultSet', 'some_value'],"name" => $row['Help']);

如果您的2个Y值不变,则可能看不到显示的图形线。 折线图会更合适吗?

经过反复试验,我发现以下解决方案:

$result1 = mysqli_query($con, "select (CalYear+1) as CalYear, Year1PercWC, Year1PercBC, calyear as Help FROM table_2 where cat='1' and (CalYear+1)<year(now())");
    while($row = mysqli_fetch_array($result1))
    {        
        $point = array("x" => floatval($row['CalYear']),"y" => array(floatval($row['Year1PercWC']),floatval($row['Year1PercBC'])),"name" => floatval($row['Help']));
        array_push($data_points, $point);        
    }
echo json_encode($data_points);

问题是我需要为数据点数组中的Y值创建一个数组。 在此数组中,我可以存储图形所需的2个值。

完成此操作后,我需要将所有数值转换为float_val,以使数值周围的引号消失。

谢谢大家的帮助:)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM