6

直到2.9.4 版本,我结合使用 ChartJS 和@types/chart.js来获得所有类型的 TypeScript 支持。我使用 Webpack 和 TypeScript 的最小工作示例如下所示:

包.json:

{
  "devDependencies": {
    "@types/chart.js": "^2.9.31",
    "ts-loader": "^8.1.0",
    "typescript": "^4.2.3",
    "webpack": "^5.30.0",
    "webpack-cli": "^4.6.0",
    "webpack-dev-server": "^3.11.2"
  },
  "dependencies": {
    "chart.js": "^2.9.4"
  }
}

tsconfig.json:

{
  "compilerOptions": {
    "esModuleInterop": true,
  },
}

webpack.config.json:

module.exports = {
  entry: {
    main: "./main.ts",
  },
  module: {
    rules: [
      {
        test: /\.ts$/,
        loader: "ts-loader",
        exclude: /node_modules/,
      },
    ],
  },
};

main.ts:

import Chart from "chart.js";

new Chart("chart", {
  type: 'line',
  data: {
    labels: ['Label 1', 'Label 2', 'Label 3'],
    datasets: [{
      label: "Dataset 1",
      data: [1, 2, 3],
    }]
  },
});

索引.html:

<!DOCTYPE html>
<html>
  <body>
    <canvas id="chart"></canvas>
    <script src="main.js"></script>
  </body>
</html>

但是在更新到版本 3.0.0之后,这不再起作用(我删除了@types/chart.js,因为chart.js自该版本发布了它自己的类型):

npx webpack 服务 --mode 开发

ERROR in [...]/chartjs/main.ts
./main.ts 3:4-9
[tsl] ERROR in [...]/chartjs/main.ts(3,5)
      TS2351: This expression is not constructable.
  Type 'typeof import("[...]/chartjs/node_modules/chart.js/types/index.esm")' has no construct signatures.

但由于内置类Chart实际上有一个构造函数,我并不真正理解这个问题以及如何解决它。将 ChartJS 版本 3 与 Webpack 和 TypeScript 结合使用的预期方式是什么?

在此先感谢您提供的任何提示,这些提示将我引向正确的方向!

4

1 回答 1

3

Chart.js 3 是tree-shakeable 的,因此有必要导入和注册您将要使用的控制器、元素、比例和插件。

请查看 Chart.js 文档中的Bundlers(Webpack、Rollup 等)

于 2021-04-05T13:42:31.243 回答