0

そこで、MySQL のデータに基づいてハイチャート グラフを生成する次のスクリプトを最終的に思いつきました。

実際の HTML と Javascript は次のとおりです。

<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
    <title>Highcharts</title>

    <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script type="text/javascript">

function test(year){
   $.getJSON("data.php?year="+year, function(json){
   options.series[0].data = json['data'];
   chart = new Highcharts.Chart(options);
   });
 }
</script>
<script>
$(function () {
var chart;
$(document).ready(function() {
    $.getJSON("data.php?year=2012", function(json) {

        chart = new Highcharts.Chart({
            chart: {
                renderTo: 'container',
                type: 'line',
                marginRight: 130,
                marginBottom: 25
            },
            title: {
                text: 'Revenue vs. Overhead',
                x: -20 //center
            },
            subtitle: {
                text: '',
                x: -20
            },
            xAxis: {
                categories: ['Jan', 'Feb', 'Mar', 'Apr', 'May', 'Jun', 'Jul', 'Aug', 'Sep', 'Oct', 'Nov', 'Dec']
            },
            yAxis: {
                title: {
                    text: 'Amount'
                },
                plotLines: [{
                    value: 0,
                    width: 1,
                    color: '#808080'
                }]
            },
            tooltip: {
                formatter: function() {
                        return '<b>'+ this.series.name +'</b><br/>'+
                        this.x +': '+ this.y;
                }
            },
            legend: {
                layout: 'vertical',
                align: 'right',
                verticalAlign: 'top',
                x: -10,
                y: 100,
                borderWidth: 0
            },
            series: json
        });
    });

});

});
    </script>
</head>
<body>
 <script src="http://code.highcharts.com/highcharts.js"></script>
 <script src="http://code.highcharts.com/modules/exporting.js"></script>

<div id="container" style="min-width: 400px; height: 400px; margin: 0 auto"></div>
<button onclick="test('2013')">2013</button>
</body>
</html>

PHP ファイルは次のようになります。

<?php
$con=mysqli_connect("x","x","x","x");
$year = $_GET["year"];
$rows = array();
$rows['name'] = '2012';
$x = mysqli_query($con,"
    SELECT Logdatetime, Temp
    FROM alldata 
    WHERE YEAR(Logdatetime)=$year
    LIMIT 12"
);

while($r = mysqli_fetch_array($x)){
$rows['data'][] = $r['Temp'];
}

$result = array();
array_push($result,$rows);

print json_encode($result, JSON_NUMERIC_CHECK);

?>

問題は、それが機能し、値「2012」を年として初期グラフを生成することですが、2013 を生成したいボタンをクリックしても何も起こりません。

間違いがどこにあるのか分かりますか?ボタンクリックから呼び出しをトリガーするために使用した関数test()のどこかにあるはずですが、修正方法がわかりません。

4

0 に答える 0