问题描述
我有一个使用AmCharts库的Angular应用程序。为了使用图表,我想延迟加载AmCharts,他们建议使用promises。我遇到的问题是,类型推断似乎不起作用,我想指定要创建的常量的类型。
Integer
如果我要在顶部导入模块,则Promise.all([
import("@amcharts/amcharts4/core"),import("@amcharts/amcharts4/charts"),import("@amcharts/amcharts4/themes/animated"),]).then((modules) => {
const am4core = modules[0];
const am4charts = modules[1];
const am4themes_animated = modules[2].default;
...
const valueAxis: am4charts.ValueAxis = chart.yAxes.push(
new am4charts.ValueAxis()
);
声明会起作用,但是现在我在valueAxis
的{{1}}上收到一个错误,指出名称空间不存在。
我有什么办法可以使它工作?
解决方法
在打字稿中,您可以import only the types,而且似乎可以解决问题
所以在我的代码中,我现在有:
import type * as am4chartsTypes from "@amcharts/amcharts4/charts";
import type * as am4coreTypes from "@amcharts/amcharts4/core";
...
export class Chart {
private chart?: am4chartsTypes.XYChart;
ngAfterViewInit() {
...
this.chart = am4core.create(
this.chartWrapper.id,am4charts.XYChart
);
...
}
}