14
10

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Vue.jsの単一ファイルコンポーネントでTypeScriptを使う方法

Posted at

最初どうやるのか分からなくて、単一ファイルコンポーネントの書き方かTypeScriptどっちか諦めざるを得ないと思ったがそんなことなかった。

前提

  • typescriptts-loaderがインストールされている
  • tsconfig.json がある

方法

プロジェクト内に index.d.ts というファイルを作成し、中身を下記のように記述します。ちなみにファイルの設置箇所とファイル名についてですが、拡張子が .d.tstsconfig.json内のpathに含まれるようならどこでもどんな名前でもいいみたいです。

index.d.ts
declare module "*.vue" {
  import Vue from "vue";
  const _default: Vue;
  export default _default;
}

これによりTypeScriptが .vue の拡張子のファイルを認識してくれるようになります。

あとは単一ファイルコンポーネント内の <script> のところで lang="ts" をすればバッチリです。

Sample.vue
<template>
  <h1>tsが使える!!</h1>
</template>

<script lang="ts">
//your awesome code
</script>
14
10
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
14
10

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?