我在我的应用程序中使用 chart.js v2 ,因为当我尝试使用bower获取最新版本时,它不会拉入dist文件夹,但这是另一个问题。
我为这个插件创建了一个角度包装器,以便将它放到我的应用程序中。 包装器看起来像这样:
.controller('ChartController', function () {
var self = this;
// Create our chart
self.init = function (ctx, data, options, type) {
// Create our config
var config = angular.extend({}, { type: type || 'bar', data: data, options: options || {} });
// Create our chart
self.chart = new Chart(ctx[0], config);
};
})
.directive('ngChart', function () {
return {
restrict: 'A',
controller: 'ChartController',
scope: {
data: '=ngChart',
type: '@',
options: '='
},
link: function (scope, element, attrs, controller) {
scope.$watch('type', function () {
controller.init(element, scope.data, scope.options, scope.type);
});
scope.$watch('data', function () {
controller.init(element, scope.data, scope.options, scope.type);
});
}
};
});
你可以看到这很简单。 在我的控制器中我有这个:
self.reportType = 'raw';
self.reportTypes = [{ name: 'Raw data', type: 'raw' }, { name: 'Bar chart', type: 'bar' }, { name: 'Line chart', type: 'line' }];
在我看来,我有这个:
<div class="inputs">
<div class="portlet-input input-inline input-small">
<select class="form-control" ng-model="controller.reportType" ng-change="controller.test()" ng-options="type.type as type.name for type in controller.reportTypes">
</select>
</div>
</div>
<div ng-if="controller.list.length && controller.reportType !== 'raw'">
<div class="form-group">
<button class="btn btn-default" ng-print><i class="fa fa-print"></i> Print</button>
</div>
<canvas class="print-only screen-only" ng-chart="controller.chartData" type="{{ controller.reportType }}"></canvas>
</div>
目前我只显示图表,如果类型不是原始的。 当我选择行时,它会绘制折线图,如果我然后选择栏,它将不会执行任何操作。 我尝试过各种各样的东西让它重绘,但它似乎不起作用。最新的建议是扩展配置(这是我在init方法中所做的)所以创建一个副本然后使用该配置副本来创建一个新的图表。 这没用。
有谁知道如何让它发挥作用?
答案 0 :(得分:0)
我发现如果我修改了数据,那么图表就会重新开始。 因此,考虑到这一点,我将我的init方法更改为:
// Create our chart
self.init = function (ctx, data, options, type) {
// Create our config
var config = { type: type || 'bar', data: angular.copy(data), options: options || {} };
// Create our chart
self.chart = new Chart(ctx[0], config);
};
这很有效,现在可以正确重绘。 我想这是因为它必须检查数据是否已经改变,如果我复制那么它总是在改变。