--- id: wiki-2026-0508-vue-architecture title: Vue Architecture category: 10_Wiki/Topics status: verified canonical_id: self aliases: [Vue 3, Composition API, Vue Reactivity] duplicate_of: none source_trust_level: A confidence_score: 0.9 verification_status: applied tags: [vue, reactivity, composition-api, frontend] raw_sources: [] last_reinforced: 2026-05-10 github_commit: pending tech_stack: language: typescript framework: vue3 --- # Vue Architecture ## 매 한 줄 > **"매 Proxy 기반 매 fine-grained reactivity 매 Composition API 의 의 의 component logic"**. 매 Evan You 매 2014 출시, 매 Vue 3 (2020) 매 Proxy + Composition API 의 매 큰 redesign — 매 2026 매 Vue 3.5 + Vapor Mode (compile-time, no virtual DOM) 매 stable, Nuxt 3 매 Vue 3 ecosystem 의 backbone. ## 매 핵심 ### 매 Reactivity (Proxy-based) - `ref(v)`: primitive wrapper, `.value` 매 access. - `reactive(obj)`: deep Proxy on object. - `computed(fn)`: lazy + cached derived. - `watch / watchEffect`: side-effect tracking. - 매 dependency 매 자동 collected — getter call 매 track, setter 매 trigger. ### 매 Composition API - ` ``` ### Composable (custom hook) ```ts // useCounter.ts import { ref, computed } from "vue"; export function useCounter(initial = 0) { const count = ref(initial); const double = computed(() => count.value * 2); function inc() { count.value++; } function reset() { count.value = initial; } return { count, double, inc, reset }; } ``` ### Props + emits + v-model (Vue 3.4 defineModel) ```vue ``` ### Pinia store ```ts import { defineStore } from "pinia"; export const useCart = defineStore("cart", () => { const items = ref<{ id: string; qty: number }[]>([]); const total = computed(() => items.value.reduce((s, i) => s + i.qty, 0)); function add(id: string) { const ex = items.value.find((i) => i.id === id); if (ex) ex.qty++; else items.value.push({ id, qty: 1 }); } return { items, total, add }; }); ``` ### Async component + Suspense ```vue ``` ### Provide / inject (typed) ```ts // keys.ts import type { InjectionKey, Ref } from "vue"; export const ThemeKey: InjectionKey> = Symbol("theme"); // Parent.vue import { provide, ref } from "vue"; const theme = ref<"light" | "dark">("dark"); provide(ThemeKey, theme); // Child.vue import { inject } from "vue"; const theme = inject(ThemeKey)!; ``` ### Watcher patterns ```ts import { ref, watch, watchEffect } from "vue"; const query = ref(""); watch(query, async (q, prev, onCleanup) => { const ctrl = new AbortController(); onCleanup(() => ctrl.abort()); const r = await fetch(`/api?q=${q}`, { signal: ctrl.signal }); // … }, { debounce: 300 } as any); // VueUse 매 watchDebounced 권장 ``` ### Vapor Mode (Vue 3.5+, compile-time, no VDOM) ```vue ``` ## 매 결정 기준 | 상황 | Approach | |---|---| | 신규 Vue project | Vue 3.5 + `