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でのシェアをお願いしております。
コメントもお待ちしております。
誤植や勘違いなどございましたらコメント欄にて教えていただけると幸いです。

直接契約ができるフリーランスエージェント「エンハンス」を立ち上げました。
詳しくは下記LPをご参照ください。
https://enhance.decryption.co.jp/

Youtubeチャンネル開設いたしました。
チャンネル登録者10,000人を目指しているので、良いと思った方はチャンネル登録をお願いしたいです。
https://www.youtube.com/channel/UC219XhmSRxmXltTy6COxSMw






Vue.js

Posted by ちこ