---
id: wiki-2026-0508-dom-vs-virtual-dom
title: DOM vs Virtual DOM
category: 10_Wiki/Topics
status: verified
canonical_id: self
aliases: [DOM, Virtual DOM, vDOM, reconciliation, diffing, React fiber, Solid signals, Svelte compile]
duplicate_of: none
source_trust_level: A
confidence_score: 0.93
verification_status: applied
tags: [frontend, dom, virtual-dom, react, fiber, solid, svelte, signals, fine-grained-reactivity]
raw_sources: []
last_reinforced: 2026-05-10
github_commit: pending
tech_stack:
language: JavaScript / React / Solid / Svelte
framework: React / Solid / Svelte / Vue
---
# DOM vs Virtual DOM
## 매 한 줄
> **"매 DOM mutation 의 expensive — 매 abstraction 의 batch"**. React 의 Virtual DOM (2013). 매 modern: 매 fine-grained reactivity (Solid, Svelte, Vue 3) 의 vDOM 의 supersede 의 trend. 매 pure DOM (vanilla, htmx) 의 revival.
## 매 핵심
### Real DOM
- 매 browser 의 tree.
- 매 mutation 의 reflow / repaint 의 trigger.
- 매 manual update 의 error-prone.
### Virtual DOM (React)
- 매 lightweight JS object 의 in-memory.
- 매 declarative state.
- 매 diff + 매 reconciliation 의 minimal real DOM update.
### 매 React 의 algorithm
1. 매 새 Virtual DOM tree.
2. 매 diff vs 매 previous (heuristic O(n)).
3. 매 minimal real DOM mutation.
### 매 React 의 heuristic
- **Different type** → 매 entirely new tree.
- **`key` attribute** → 매 stable child identity.
- **Component type same + props different** → 매 update only changed.
### 매 modern alternative
#### Fine-grained reactivity (Solid, Svelte 5, Vue 3)
- 매 vDOM 의 X.
- 매 signal / effect 의 specific DOM 의 update.
- 매 faster + smaller bundle.
#### Compile-time (Svelte)
- 매 framework 의 compile away.
- 매 매 component 의 specific imperative code.
#### htmx / Pure HTML
- 매 server-side render + 매 partial swap.
- 매 매 minimum JS.
### 매 trade-off
| 측면 | Real DOM | Virtual DOM | Fine-grained |
|---|---|---|---|
| Direct manipulation | Manual | Abstracted | Abstracted |
| Update granularity | Per-mutation | Per-component | Per-signal |
| Memory | Low | Medium | Low |
| Bundle size | Tiny | 50KB+ (React) | <10KB (Solid) |
| Rendering speed | Variable | Good | Best |
| Mental model | Imperative | Declarative + render fn | Declarative + signals |
### 매 React Fiber (2017)
- 매 reconciliation 의 interruptible.
- 매 priority-based.
- 매 concurrent rendering.
- 매 React 18+ default.
### 매 modern React 18+ optimization
- **Concurrent rendering**: 매 interrupt.
- **Automatic batching**.
- **Suspense + streaming**.
- **`useTransition` / `useDeferredValue`**.
- **RSC** (Server Components).
### 매 응용
1. **Large dynamic UI**: React / Solid.
2. **Static + light interactivity**: htmx / Astro islands.
3. **Form-heavy**: Solid (fast).
4. **SEO-critical**: Next.js (SSR).
5. **Data viz**: D3 + minimal framework.
## 💻 패턴
### React (declarative)
```jsx
function Counter() {
const [count, setCount] = useState(0);
return (
);
}
// React 가 매 setCount 시 의 새 vDOM → diff → 매 button text 만 update.
```
### `key` for stable identity
```jsx
function List({ items }) {
return (