仅在数据存在时显示Google图表

时间:2012-11-26 16:31:49

标签: javascript function charts call

我有一个使用SQL数据的Google折线图。但是,当查询返回0行时,它会在页面上显示一个大的空图表。我想改为显示一些文字,说没有数据。我尝试将图表函数包装在我调用的另一个函数中,如果存在数据,但是没有显示任何内容,即使数据存在也是如此。以下是我的一些代码:

<script type="text/javascript" src="https://www.google.com/jsapi"></script>
<script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/jquery/1/jquery.min.js"></script>
<script type="text/javascript">
google.load("visualization", "1", {packages:["corechart"]});
function displayChart()
{
    $(document).ready(function()
    {
        google.setOnLoadCallback(drawChart);
    });
}
function drawChart() 
{
// Here we tell it to make an ajax call to pull the data from the .json file
    var jsonData = $.ajax({
    url: "Data.json",
    dataType:"json",
    async: false
}).responseText;

// Create our data table out of JSON data loaded from server.
var data = new google.visualization.DataTable(jsonData);

// Options for the graph, we set chartArea to get rid of extra whitespace
var options = {
                'width':1300,
                'height':500,
                'chartArea': {top:'10%', left:'5%', height:'75%', width:'85%'}
              };

// Instantiate and draw our chart, passing in some options and putting it in the chart_div.
var chart = new google.visualization.LineChart(document.getElementById('chart_div'));
chart.draw(data,options); 
}
</script>
<?

...

if($got_data == true)
{
    displayChart();
}
else
    echo "There is no data";

知道我做错了什么,或者更好的方法来实现这个目标?提前谢谢!

1 个答案:

答案 0 :(得分:0)

正如Serg的评论所说,你需要设置是否在ajax调用的回调中显示你的图表。这是因为当您致电$.ajax()时,您的ajax调用返回的数据不存在也无法访问。如果你看不起JQuery AJAX page,你会看到几个如何处理来自ajax调用的数据的例子,但你要找的是如下内容:

$.ajax({
    url: "Data.json",
    dataType:"json",
    async: false
}).complete(function(data) {
    if (data) {
        // draw chart
    } else {
        // say no data
    }
);