vue-chartjs+TypeScriptでClass ” incorrectly extends base class ‘Bar & ReactivePropMixin & …

今回はvue-chartjs+TypeScriptを使用しているときに、「class ” Class ” incorrectly extends base class ‘Bar & ReactivePropMixin & Vue & object & Record‘.
Type ” is not assignable to type ‘ReactivePropMixin’.
Property ‘chartData’ is private in type ” but not in type ‘ReactivePropMixin’.」というエラーが出たときの対処法についてご紹介いたします。



vue-chartjs+TypeScriptでClass ” incorrectly extends base class ‘Bar & ReactivePropMixin & …

vue-chartjsとTypeScript環境で開発を行っているときのことです。
上記のエラーが出てしまいました。

このときのソースコードは下記のようなコードでした。

上記のコードのとき、VS Code上でclassを定義するtestChartのところにマウスカーソルを乗せると上記のエラーが出ます。

結論から言うと、上記ソースコードだとchartDataがprivateになっていますが、publicにすることで上記エラーが消えます。
こんな感じですね。

おそらくですが、vue-chartjsのGitHubのソースコードを見てみると、watchでchartDataを見ているので、privateのままだとvue-chartjsからchartDataを見れないのでエラーが出るわけですね。
https://github.com/apertureless/vue-chartjs/blob/develop/src/mixins/index.js#L95-L97

終わりに

今回はvue-chartjs+TypeScriptを使用しているときに、「class ” Class ” incorrectly extends base class ‘Bar & ReactivePropMixin & Vue & object & Record‘.
Type ” is not assignable to type ‘ReactivePropMixin’.
Property ‘chartData’ is private in type ” but not in type ‘ReactivePropMixin’.」というエラーが出たときの対処法についてご紹介いたしました。

最後までお読みいただきありがとうございます。
ブログやTwitterでのシェアOKです。
コメントもお待ちしております。
誤植や勘違いなどございましたらコメント欄にて教えていただけると幸いです。






Vue.js

Posted by ちこ