如何更改DataTable'使用Javascript的Google Chart API

How to change the format in the DataTable's Google Chart API with Javascript

本文关键字:Javascript Google Chart API 使用 何更改 DataTable      更新时间:2023-09-26
  • 我想更改中DataTable中数据的格式为了使其更加灵活,图表仍然与第一个

默认值:

['Year', 'Sales', 'Expenses'],
['2004',  1000,      400],
['2005',  1170,      460],
['2006',  660,       1120],
['2007',  1030,      540]

必须是:

['Year', '2004', '2005', '2006', '2007'],
['Sales', 1000, 1170, 660, 1030],
['Expenses', 400 ,460, 1120, 540]

演示


HTML:

<div id="chart_div" style="width: 450px; height: 300px;"></div>

Javascript:

google.load("visualization", "1", {packages:["corechart"]});
  google.setOnLoadCallback(drawChart);
  function drawChart() {
    var data = google.visualization.arrayToDataTable([
      ['Year', 'Sales', 'Expenses'],
      ['2004',  1000,      400],
      ['2005',  1170,      460],
      ['2006',  660,       1120],
      ['2007',  1030,      540]
    ]);
    var options = {
      title: 'Company Performance'
    };
    var chart = new google.visualization.LineChart(document.getElementById('chart_div'));
    chart.draw(data, options);
  }

您必须转置数组,如下所示:http://jsfiddle.net/krzysztof_safjanowski/Mw398/1/

var data = google.visualization.arrayToDataTable(transposeArray([
    ['Year', '2004', '2005', '2006', '2007'],
    ['Sales', 1000, 1170, 660, 1030],
    ['Expenses', 400, 460, 1120, 540]
]));
function transposeArray(array) {
  return array[0].map(function (col, i) {
    return array.map(function (row) {
      return row[i];
    });
  });
}

在将数据传递给arrayToDataTable之前,您必须以谷歌图表能够理解的格式进行准备。

Transpose–http://en.wikipedia.org/wiki/Transpose

方法map-https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/map