vue-composition-api
SKILL.md
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
Resources
Weekly Installs
2
Repository
spjoshis/claude…-pluginsGitHub Stars
3
First Seen
Feb 21, 2026
Security Audits
Installed on
opencode2
claude-code2
github-copilot2
codex2
kimi-cli2
gemini-cli2