data:image/s3,"s3://crabby-images/3ee92/3ee92f96145a5d36a6d881b0cdf0efef1af050fd" alt="パソ君"
・Vue.jsのコードTypeScriptはどう使うの?
こんな疑問にお答えします。
Vue.jsで使うrefやcomputedなどなどは、TypeScriptの書き方にすることが可能です。
今回は自分用のメモとしてVue.jsでよく使うコードをTypeScriptでの書き方にまとめてみました!
data:image/s3,"s3://crabby-images/17371/173713cf8bd4265b79ed3f9efd228bdd35c0b78f" alt="ジト"
参考にどうぞ
TypeScriptの型定義については下記記事をどうぞ↓
data:image/s3,"s3://crabby-images/b19c6/b19c6a6f726edc6efdfad2d721a15acac29e661d" alt=""
・Vue.jsのコードでTypeScriptを使う書き方
data:image/s3,"s3://crabby-images/9355c/9355c75f96a22c7712f1a718be7427dac8301866" alt=""
data:image/s3,"s3://crabby-images/1d090/1d090e74e891df89b1e962f09b8f0c9e0db478c6" alt=""
目次
【解説】Vue.js+TypeScriptでよく使う型定義【まとめてみた】
Vue.js+TypeScriptの型定義は主に下記があります。
・ref
・reactive
・watch
・watchEffect
・computed
・イベントハンドラー
・props
・useTemplateRef
順に見ていきましょう。
基本的にrefは型推論されます。
定義するときはrefのあとに<>にて記述します。
<script setup lang="ts">
import {ref} from 'vue'
const fruit = ref<string>('りんご')
const num = ref<number>(10)
const mixItem = ref<string | number>('おはよう')
mixItem.value = 10
</script>
data:image/s3,"s3://crabby-images/c30f0/c30f07f2c818c78312fe56231b3068550a4fcd99" alt=""
基本的にreactiveは型推論されます。
定義するときはreactiveのあとに<>にて記述したり、
<script setup lang="ts">
import { reactive } from 'vue'
const state = reactive<{ fruit: string, num: number, mixItem: string | number }>({
fruit: 'りんご',
num: 10,
mixItem: 'おはよう'
})
state.mixItem = 10
</script>
インターフェースを用いても実装可能です。
<script setup lang="ts">
import { reactive } from 'vue'
interface State {
fruit: string
num: number
mixItem: string | number
}
const state = reactive<State>({
fruit: 'りんご',
num: 10,
mixItem: 'おはよう'
})
state.mixItem = 10
</script>
data:image/s3,"s3://crabby-images/ab3f7/ab3f70330e379a8da0e87d817220064c1199f757" alt=""
watchではコールバック関数の引数部分や、戻り値に対して型定義することができます。
<script setup lang="ts">
import { ref, watch } from 'vue'
const num = ref<number>(0)
watch(num, (newVal: number, oldVal: number): void => {
console.log(`元々の数値は${oldVal} 新しい数値は${newVal}`)
});
</script>
<template>
<p>{{ num }}</p>
<button @click="num++">クリック!</button>
</template>
data:image/s3,"s3://crabby-images/5f389/5f38972b0b4079c5397397a95b229cbe15f910b0" alt=""
watchEffectでは戻り値に対して型定義することができます。
<script setup lang="ts">
import { ref, watchEffect } from 'vue'
const num = ref<number>(0)
watchEffect((): void => {
console.log(num.value)
})
</script>
<template>
<p>{{ num }}</p>
<button @click="num++">クリック!</button>
</template>
computedも基本的には型推論されます。
定義するときはcomputedのあとに<>にて記述します。
<script setup lang="ts">
import { ref, computed } from 'vue'
const num = ref<number>(0)
const numAdd = computed<number>(() => {
return num.value + 10
})
numAdd.value
</script>
data:image/s3,"s3://crabby-images/41b36/41b36682f6317d19064fe5a7db5f2fe3ac0e4f17" alt=""
イベントハンドラー関数の引数が、どの型のオブジェクトになるかを明確にします。
下記の例でいうと(e: MouseEvent)部分ですね。
<script setup lang="ts">
import { ref } from 'vue'
const num = ref<number>(0)
function numAdd(e: MouseEvent) {
num.value++
}
</script>
<template>
<p>数値:{{num}}</p>
<button @click="numAdd">クリック!</button>
</template>
ようは引数のeがMouseEvent(マウスイベント)ということを示しています。
ちなみに形はイベント名をホバーすれば表示されるんですよね。
data:image/s3,"s3://crabby-images/31102/31102ba834af86f7439f04beaeeb2502e2efefd1" alt=""
こちらをコピペすればOK。
data:image/s3,"s3://crabby-images/17371/173713cf8bd4265b79ed3f9efd228bdd35c0b78f" alt="ジト"
このようなイベントオブジェクトの型は
TypeScriptにデフォルトで用意されてるよ!
propsでの型定義のやり方は色々あります。
まずJavaScriptを使用した書き方がこちら↓
<script setup lang="ts">
defineProps({
title: {
type: String,
required: true
}
})
</script>
個人的にはこのやり方が書きやすい気がしますね。
そして以下がTypeScriptの型を使用したものとなります。
型引数にて定義する場合は、このような書き方↓
<script setup lang="ts">
defineProps<{
title: string
}>()
</script>
インターフェースを使う場合は、このような書き方でも可能です↓
<script setup lang="ts">
interface Child {
title: string
}
defineProps<Child>()
</script>
ちなみに上記らの「required」はデフォルトでtrueになっています。
falseにしたい場合は「?」をつければ実装可能です。
title?: string
data:image/s3,"s3://crabby-images/96fdb/96fdb50d6b3cfe799920448247e2498009bc65d3" alt=""
TypeScriptの型ベースにて宣言したpropsで、デフォルト値を宣言するには「withDefaults」を使います。
<script setup lang="ts">
interface Child {
title?: string
}
withDefaults(defineProps<Child>(),{
title: 'タイトル名'
})
</script>
第一引数にdefinePropsの呼び出し式を、第二引数にオブジェクトにてキーとデフォルトの値を記述します。
これでデフォルトの値を宣言することが可能です。
useTemplateRefも基本的には型推論されます。
テンプレート内のタグの要素を調べてくれます。
定義するときはuseTemplateRefのあとに<>にて記述します。
<script setup lang="ts">
import { useTemplateRef, onMounted } from 'vue';
const usetItem = useTemplateRef<HTMLInputElement>('test-item');
onMounted(() => {
usetItem.value?.focus();
})
</script>
<template>
<input ref="test-item" type="text">
</template>
data:image/s3,"s3://crabby-images/ef186/ef1869defff3c3af3152b9e1c5fc2796cb8d9b29" alt=""
【解説】Vue.js+TypeScriptでよく使う型定義【まとめてみた】
- ref
- reactive
- watch
- watchEffect
- computed
- イベントハンドラー
- props
data:image/s3,"s3://crabby-images/17371/173713cf8bd4265b79ed3f9efd228bdd35c0b78f" alt="ジト"
Vue.jsのコードをTypeScriptで使うときはためしてみてね!
data:image/s3,"s3://crabby-images/9355c/9355c75f96a22c7712f1a718be7427dac8301866" alt=""
data:image/s3,"s3://crabby-images/1d090/1d090e74e891df89b1e962f09b8f0c9e0db478c6" alt=""