| name | vue-composition-api |
| description | Master Vue 3 Composition API with setup, ref, reactive, computed, watch, and composables for building scalable reactive applications. |
Vue Composition API
Master Vue 3's Composition API for building scalable, reusable, and type-safe reactive applications.
Core Concepts
Script Setup
<script setup lang="ts">
import { ref, computed } from 'vue'
const count = ref(0)
const doubled = computed(() => count.value * 2)
function increment() {
count.value++
}
</script>
<template>
<div>
<p>{{ count }} x 2 = {{ doubled }}</p>
<button @click="increment">Increment</button>
</div>
</template>
Composables
// composables/useFetch.ts
export function useFetch<T>(url: string) {
const data = ref<T | null>(null)
const error = ref<Error | null>(null)
const loading = ref(true)
const fetchData = async () => {
loading.value = true
try {
const response = await fetch(url)
data.value = await response.json()
} catch (e) {
error.value = e as Error
} finally {
loading.value = false
}
}
onMounted(fetchData)
return { data, error, loading, refetch: fetchData }
}
Reactive State
import { reactive, toRefs } from 'vue'
const state = reactive({
count: 0,
message: 'Hello'
})
// Destructure while maintaining reactivity
const { count, message } = toRefs(state)
Best Practices
- Use
reffor primitives,reactivefor objects - Extract reusable logic into composables
- Use TypeScript for type safety
- Implement proper cleanup in
onUnmounted - Use
computedfor derived state - Leverage
watchEffectfor side effects