有没有人设法让Chartjs在AngularDart中工作?

时间:2017-02-12 04:55:59

标签: dart angular-dart

更新:已解决。我错过了index.html文件中的Chartjs脚本包含,糟糕

    <script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.4.0/Chart.min.js"></script>

它仅适用于 Dart 示例,但它似乎不适用于 AngularDart

我正在使用新的 Angular Web应用程序,并根据 Dart 示例进行了修改。

我添加了 app_component.html 相同的 DIV 元素,只有一个例外,那是一个本地变量,所以我可以通过 ViewChild :

<div>
  <p>Canvas</p>
  <div class="wrapper">
      <canvas #theCanvas id="canvas" height="450" width="600"></canvas>
  </div>
</div>

然后我将样式添加到 app_component.css (加上边框以查看画布)。我甚至可以绘制一个矩形并看到它:

div.wrapper {
 margin: 0 auto;
 max-width: 800px;
 text-align: center;
 font-style: italic;
 border: #6bc5ff 1px solid;
}

然后我将Dart示例中的相同图表代码添加到 app_commponent.dart 文件中:

 Angular imports...
 import 'package:chartjs/chartjs.dart';

 @Component(
    selector: 'my-app',
    styleUrls: const ['app_component.css'],
    templateUrl: 'app_component.html',
    directives: const [materialDirectives, HelloDialog],
    providers: const [materialProviders],
)
class AppComponent implements AfterContentInit, AfterViewInit {
  @ViewChild('theCanvas')
  ElementRef canvas;

  CanvasElement canvasEl;

  math.Random rnd = new math.Random();
  List<String> months = <String>[
    "January", "February", "March", "April", "May", "June"];

  ngAfterContentInit() {
    canvasEl = canvas.nativeElement;
  }

  ngAfterViewInit() {
    var data = new LinearChartData(labels: months, datasets: <ChartDataSets>[
      new ChartDataSets(
          label: "My First dataset",
          backgroundColor: "rgba(220,220,220,0.2)",
          data: months.map((_) => rnd.nextInt(100)).toList()),
      new ChartDataSets(
          label: "My Second dataset",
          backgroundColor: "rgba(151,187,205,0.2)",
          data: months.map((_) => rnd.nextInt(100)).toList())
    ]);

    var config = new ChartConfiguration(
        type: 'line', data: data, options: new ChartOptions(responsive: true));

    Chart chart = new Chart(canvasEl, config);
  }
}

我将依赖项添加到 pubspec.yaml

chartjs:

其中包括js依赖。正如我所提到的,我可以进行绘制调用,比如画线,所以我知道画布有效。

Dartium的控制台显示错误:

Uncaught Unhandled exception:
Not a valid JS object
#0      JsNative.callConstructor (dart:js:1461)
#1      Chart.Chart (package:chartjs/chartjs.dart_js_interop_patch.dart:31:30)
#2      AppComponent.ngAfterViewInit (package:DeuronNG/app_component.dart:59:23)
...

有人知道我错过了什么或JS错误意味着什么吗?

1 个答案:

答案 0 :(得分:1)

我错过了index.html文件中的Chartjs脚本包含,Oops:

<script src="https://cdnjs.cloudflare.com/ajax/libs/Chart.js/2.4.0/Chart.min.js"></script>