javascript - Google Charts 不显示数据

标签 javascript titanium google-visualization titanium-mobile

我正在使用 Titanium Studio 制作一个应用程序,并尝试使用 webView 和 Google Charts 来可视化一些数据。数据在二维数组中,如下所示:

[["Tendency","Number of Answers"],["Item one", 2],["Item two", 5]]

这是我用来传递数据的代码:

function Graph(data){
var chart = Ti.UI.createWebView({
    url: "/results.html",
    width: Ti.UI.SIZE,
    height: "auto",
    top: 110
});

for (var i=0, l=data.length; i<l; i++){
    if (data[i] instanceof Array) data[i] = data[i].join(";");
}
var syndata = data.join("@");

chart.addEventListener('beforeload',function(e){
    chart.evalJS("var syndata ='"+syndata+"';");
});

this.chart = chart;

return;
};

module.exports = Graph;

我尝试传递不同种类的数据,发现它只适用于字符串,所以我将数组转换为字符串 “趋势;答案数@Item1;2@……” 在 results.html 中,我再次将其转换为数组,并将其读入图表:

<script type="text/javascript" src="https://www.google.com/jsapi"></script>
<script type="text/javascript">
var dt = syndata.split("@");
for(var i = 0, l = dt.length; i<l; i++) dt[i] = dt[i].split(";");

  google.load("visualization", "1", {packages:["corechart"]});
  function drawChart(d) {

    var data = google.visualization.arrayToDataTable(d);

    var options = {
      title: 'Overview',
      chartArea:{left:5,top:5,width:"100%",height:"100%"}
    };

    var chart = new google.visualization.PieChart(document.getElementById('chart'));
    chart.draw(data, options);
  }

  google.setOnLoadCallback(function(){ drawChart(dt) });
</script>

但是,我只得到一张灰色图表,其中有一项显示“其他”。当我将数组直接粘贴到文件中并从中引用时它工作正常......我尝试直接从 results.html 输出带有 Ti.API.info 的数组以查看是否有错误,但一切似乎都很好。有任何想法吗?

最佳答案

关于javascript - Google Charts 不显示数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12780869/

相关文章:

javascript - 使用instanceof测试对象

android - Titanium:创建下方带有文本的按钮

javascript - 如何更改谷歌图表工具提示的弹出位置

javascript - 当我按下按钮时,页面只是空白并永远加载

php - 谷歌可视化 API php ajax

javascript - 将 ES2017 异步与 jQuery .ready() 一起使用

javascript - 这个 JavaScript 对象是如何转换为字符串的?

javascript - 如何正确使用SVG checkintersection()函数?

android - res/drawable/Icon.png 位于 Titanium Studio IDE 中的什么位置?

titanium - 如何在钛中设置请求 header