我正在使用Angular v2(2.0.0-beta-1
)并使用Google Charts显示一个简单的图表。
import {Component, View} from "angular2/core";
import {Http, HTTP_PROVIDERS} from "angular2/http";
import {OnInit, OnDestroy} from 'angular2/core';
declare let io: any;
declare let google: any;
@Component({
selector:'default',
viewProviders: [HTTP_PROVIDERS]
})
@View({
templateUrl: 'app/default/default.html'
})
export class DefaultPage implements OnInit, OnDestroy {
charttitle: string;
data: any;
options: any;
timerToken: any;
chart: any;
socket: any;
constructor(http: Http) {
}
ngOnInit() {
console.log("onInit");
this.charttitle = "Sample Graph using live data";
this.options = {
title: "My Daily Activities",
is3D: true
};
this.socket = io();
this.socket.on("data_updated", (msg) => {
this.data = new google.visualization.DataTable();
this.data.addColumn('string', 'Task');
this.data.addColumn('number', 'Hours per Day');
this.data.addRows(5);
let data = JSON.parse(msg).activityData;
for (let i = 0; i < data.length; i++) {
let act = data[i];
this.data.setCell(i, 0, act.act);
this.data.setCell(i, 1, act.value);
}
this.chart.draw(this.data, this.options);
});
this.chart = new google.visualization.PieChart(document.getElementById('chart_div'));
google.visualization.events.addListener(this.chart, 'select', this.mySelectHandler);
}
mySelectHandler() {
console.trace();
console.log("Chart: " + this);
//let selectedItem = this.chart.getSelection()[0];
/*if (selectedItem) {
let value = this.data.getValue(selectedItem.row, 0);
console.log("The user selected: " + value);
}*/
}
ngOnDestroy() {
console.log("onDestroy");
this.socket.disconnect();
}
}
我遇到的问题是以下几行。
google.visualization.events.addListener(this.chart, 'select', this.mySelectHandler);
注册事件的时间是选择饼图上的元素时触发实际事件处理程序。但是由此引用的所有Angular JS 2范围变量都不在范围内。就像Google Chart可视化库在其自己的范围内运行一样。
我知道Angular JS有Angular-Charts指令但我们不能使用它,因为公司只想使用Angular v2。
有没有办法让Google Charts API将事件“冒泡”到在Angular组件范围内运行的事件处理程序。
如果你想要你的mySelectHandler
参与Angular2上下文/变化检测,你可以利用NgZone
,如下所述。这样,您在此函数中所做的更改将相应地更新视图。
import {NgZone} from 'angular2/core';
export class DefaultPage implements OnInit, OnDestroy {
constructor(private ngZone:NgZone) {
}
ngOnInit()
this.chart = new google.visualization.PieChart(
document.getElementById('chart_div'));
google.visualization.events.addListener(
this.chart, 'select', () => {
this.ngZone.run(() => {
this.mySelectHandler();
});
}
);
}
}
希望我正确理解你的问题。蒂埃里