---
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
Loading…
```
### 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 + `]