php - 带列标签的 Mysql 到 Google 图表

标签 php mysql label google-visualization

我正在尝试创建带有列标签的谷歌图表。以下内容对我来说效果很好。除了当我尝试将它与从 mysql 表创建的 Json 数据一起使用时。你们能帮助我了解我做错的地方吗?

工作 Google 图表代码:

<script type="text/javascript">
    function drawVisualization() {

    var data = google.visualization.arrayToDataTable([
        ['From', 'TotalOrders', 'Quantity'],
        ['Wk of 9/7/14', 172, 8910],
        ['Wk of 9/14/14', 121, 5901],
        ['Wk of 9/21/14', null, null],
        ['Wk of 9/28/14', null, null]
    ]);


    var formatter = new google.visualization.NumberFormat( {pattern:'#,###'});
    formatter.format(data, 1);
    formatter.format(data, 2);

    mydiv = $("#mychart");
    chart = new google.visualization.ComboChart(mydiv[0]);
    chart.draw(data, {
        width: 600, height: 400, seriesType: 'bars',
        chartArea: {left: 60, top: 30, width: 540}
    });    


    rects = mydiv.find('svg > g > g > g > rect');
    var row = 0;
    for (i = 0; i < rects.length; i++) {

        el = $(rects[i]);
        if (parseFloat(el.attr("height")) <= 2) { continue; }
        aparent = el.parent();
        do { // skips 'null' values
            text = data.getValue(row++, 1);
        } while (text == null && row < data.getNumberOfRows());

        if (text) {
            text = formatter.formatValue(text);
            // see below
            pos = getElementPos(el);
            attrs = {x: pos.x + pos.width / 2, y: pos.y - 2,
                fill: 'black',
                'font-family': 'Arial', 'font-size': 11,
                'text-anchor': 'middle'};
            aparent.append(addTextNode(attrs, text, aparent));
        }
    }
}


google.load('visualization', '1', {packages: ['corechart']});
google.setOnLoadCallback(drawVisualization);

function getElementPos($el) {
    return {
        x: parseInt($el.attr("x")),
        width: parseInt($el.attr("width")),
        y: parseInt($el.attr("y")),
        height: parseInt($el.attr("height"))
    }
}


function addTextNode(attrs, text, _element) {
    var el = document.createElementNS('http://www.w3.org/2000/svg', "text");
    for (var k in attrs) { el.setAttribute(k, attrs[k]); }
    var textNode = document.createTextNode(text);
    el.appendChild(textNode);
    return el;
}

</script>

但是当我将它与以下内容一起使用时,它不起作用。

$table = array();
$table['cols'] = array(
    array('label' => 'From', 'type' => 'string'),
    array('label' => 'TotalOrders', 'type' => 'number'),
    array('label' => 'Quantity', 'type' => 'Number')
);

$rows = array();
while($r = mysql_fetch_assoc($sth)) {
    $temp = array();
    $temp[] = array('v' => (string) $r['From']); 
    $temp[] = array('v' => (int) $r['TotalOrders']); 
    $temp[] = array('v' => (int) $r['Quantity']); 
    $rows[] = array('c' => $temp);
}

$table['rows'] = $rows;
$jsonTable = json_encode($table);

我似乎找不到这里出了什么问题。也许你们能够为我指明正确的方向。

最佳答案

该 JSON 结构与 arrayToDataTable 函数不兼容 - 您必须使用常规 DataTable 构造函数:

var data = new google.visualization.DataTable(<?php echo $jsonTable; ?>);

此外,您应该让 json_encode 函数正确解析输出中的数字,否则它们可能会显示为字符串:

$jsonTable = json_encode($table, JSON_NUMERIC_CHECK);

关于php - 带列标签的 Mysql 到 Google 图表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25818110/

相关文章:

PHP : Decrypt password from hash

html - 页面问题中有多个相同的表单标签

mysql - 如何在mysql中获取每个月的汇总数据

mysql - 如何在同一个表mysql中创建一列的副本

mysql - 限制用户的服务器资源时出错

css - html 元素对齐

css - 如何隐藏 <label for =""> CSS

php - 如何在php和zend框架中使用twitter Oauth get请求来检索一些用户数据

PHP(PHP4) 循环更新数据在 CentOS 上获得 "500 Internal Server Error"但在 Windows 上没有(XAMPP)

php - 优化与 mysql 的连接