Skillshub vue
Vue 3 Composition API, script setup macros, reactivity system, and built-in components. Use when writing Vue SFCs, defineProps/defineEmits/defineModel, watchers, or using Transition/Teleport/Suspense/KeepAlive.
install
source · Clone the upstream repo
git clone https://github.com/ComeOnOliver/skillshub
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/ComeOnOliver/skillshub "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/antfu/skills/vue" ~/.claude/skills/comeonoliver-skillshub-vue-7920b3 && rm -rf "$T"
manifest:
skills/antfu/skills/vue/SKILL.mdsource content
Vue
Based on Vue 3.5. Always use Composition API with
.<script setup lang="ts">
Preferences
- Prefer TypeScript over JavaScript
- Prefer
over<script setup lang="ts"><script> - For performance, prefer
overshallowRef
if deep reactivity is not neededref - Always use Composition API over Options API
- Discourage using Reactive Props Destructure
Core
| Topic | Description | Reference |
|---|---|---|
| Script Setup & Macros | , defineProps, defineEmits, defineModel, defineExpose, defineOptions, defineSlots, generics | script-setup-macros |
| Reactivity & Lifecycle | ref, shallowRef, computed, watch, watchEffect, effectScope, lifecycle hooks, composables | core-new-apis |
Features
| Topic | Description | Reference |
|---|---|---|
| Built-in Components & Directives | Transition, Teleport, Suspense, KeepAlive, v-memo, custom directives | advanced-patterns |
Quick Reference
Component Template
<script setup lang="ts"> import { ref, computed, watch, onMounted } from 'vue' const props = defineProps<{ title: string count?: number }>() const emit = defineEmits<{ update: [value: string] }>() const model = defineModel<string>() const doubled = computed(() => (props.count ?? 0) * 2) watch(() => props.title, (newVal) => { console.log('Title changed:', newVal) }) onMounted(() => { console.log('Component mounted') }) </script> <template> <div>{{ title }} - {{ doubled }}</div> </template>
Key Imports
// Reactivity import { ref, shallowRef, computed, reactive, readonly, toRef, toRefs, toValue } from 'vue' // Watchers import { watch, watchEffect, watchPostEffect, onWatcherCleanup } from 'vue' // Lifecycle import { onMounted, onUpdated, onUnmounted, onBeforeMount, onBeforeUpdate, onBeforeUnmount } from 'vue' // Utilities import { nextTick, defineComponent, defineAsyncComponent } from 'vue'