在Angular v2中处理来自Google Charts的精选活动

问题描述 投票:2回答:1

我正在使用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组件范围内运行的事件处理程序。

events google-visualization angular
1个回答
1
投票

如果你想要你的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();
         });
       }
    );
  }
}

希望我正确理解你的问题。蒂埃里

© www.soinside.com 2019 - 2024. All rights reserved.