google.visualization.PieChart不是构造函数

时间:2017-03-10 09:33:05

标签: javascript jquery graph google-chartwrapper google-pie-chart

我使用饼图来显示这里的数据是我的代码我添加了以下脚本

self.DrawServiceGraph = function (obj) {
                var dataArray = new Array();
                dataArray.push(['Services', 'Total']);
                var subCat = ko.utils.arrayFirst(self.SelectedServiceSubCategoryList(), function (o) { return o.Id === obj.Id; });
                if (subCat !== undefined) {
                    $.each(subCat.SSC_List(), function (index, item) {
                        var value = parseInt(item.Value());
                        dataArray.push([item.SSC_Name, value]);
                    });

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

                    var options = {
                        title: '', height: 230, width: 330,
                        chartArea: { left: 0, width: '100%' },
                        legend: { position: 'right', alignment: 'start', maxLines: 5, textStyle: { fontSize: 10 } }
                    };

                    var chart = new google.visualization.PieChart(document.getElementById('Services-chart' + obj.Id));
                    chart.draw(data, options);
                }
            }

和我的用于显示聊天的功能: -

{{1}}

然后我从行中得到了错误:

google.visualization.Pie图表不是构造函数 google.visualization.arrayToDataTable不是构造函数

避免此错误的可能解决方案应该是什么?

1 个答案:

答案 0 :(得分:3)

你在等待load声明完成吗?

使用callback知道何时可以开始绘图......

google.charts.load('current', {
  callback: function () {
    // begin drawing
  },
  packages: ['corechart', 'gauge']
});

- 或 -

google.charts.load('current', {
  packages: ['corechart', 'gauge']
});
google.charts.setOnLoadCallback(function () {
  // begin drawing
});