feat: Wiki 지식 자산 업데이트 - UX Scenarios, Frontend, Game Design, Topics 추가 [2026-05-08]

This commit is contained in:
2026-05-08 19:52:07 +09:00
parent 9dd3d40662
commit 5ba5a55c78
3984 changed files with 334557 additions and 28839 deletions
@@ -1,10 +1,29 @@
---
id: wiki-2026-0508-modern-scalable-frontend-archite
title: Modern Scalable Frontend Architecture
category: 10_Wiki/Topics
status: needs_review
canonical_id: self
aliases: []
duplicate_of: none
source_trust_level: A
confidence_score: 0.92
tags: [uncategorized]
raw_sources: []
last_reinforced: 2026-05-08
github_commit: pending
inferred_by: Claude Opus 4.7 (auto-normalize 2026-05-08)
tech_stack:
language: unspecified
framework: unspecified
---
# [[Modern Scalable Frontend Architecture|Modern Scalable Frontend Architecture]]
## 📌 Brief Summary
## 📌 한 줄 통찰 (The Karpathy Summary)
현대적이고 확장 가능한 프론트엔드 아키텍처는 고성능 런타임 최적화, 모듈식 컴포넌트 구조, 중앙 집중화된 디자인 토큰 시스템을 결합하여 대규모 웹 애플리케이션을 구축하는 방법론입니다 [1, 2]. React 생태계가 서버 컴포넌트(RSC) 기반으로 전환됨에 따라 [[CSS-in-JS|CSS-in-JS]]에서 Tailwind CSS와 같은 유틸리티 및 빌드 타임 기반 스타일링으로의 이동이 두드러지고 있습니다 [1, 3, 4]. 또한 Atomic Design, 복합 컴포넌트([[Compound Components|Compound Components]]) 패턴과 모노레포(Monorepo) 및 [[Feature-Sliced Design|Feature-Sliced Design]](FSD) 아키텍처를 통해 확장성과 코드 유지보수성을 극대화합니다 [5-7].
## 📖 Core Content
## 📖 구조화된 지식 (Synthesized Content)
**1. 스타일링 패러다임: [[styled-components|styled-components]] vs Tailwind CSS**
* **Styled-components의 한계:** Styled-components와 같은 런타임 CSS-in-JS는 동적인 스타일링과 컴포넌트 기반 접근 방식으로 우수한 개발자 경험을 제공하지만, 브라우저에서 [[JavaScript|JavaScript]]를 실행해 스타일을 생성하므로 성능 오버헤드가 발생합니다 [4, 8, 9]. 특히 React Context에 의존하기 때문에 서버에서 정적 HTML을 렌더링하는 [[React Server Components|React Server Components]](RSC)와 본질적으로 호환되지 않는 단점이 있습니다 [3, 10].
* **Tailwind CSS의 성능 우위:** Tailwind CSS는 빌드 타임에 정적 CSS를 생성하는 유틸리티 우선(Utility-first) 접근 방식을 취하여 런타임 오버헤드가 없고 RSC와 뛰어난 호환성을 보여줍니다 [4, 11]. JIT(Just-In-Time) 컴파일러를 통해 사용된 클래스만 번들에 포함하므로 [[Core Web Vitals|Core Web Vitals]] 최적화에 유리합니다 [4, 12]. 예를 들어, Kiwi.com의 경우 Styled-components에서 Tailwind로 마이그레이션한 후 모바일 환경에서 FID(First Input Delay)를 75.9%, INP(Interaction to Next Paint)를 58.4% 줄이는 극적인 성능 향상을 달성했습니다 [13, 14].
@@ -25,10 +44,64 @@
* **[[Feature-Sliced Design (FSD)|Feature-Sliced Design (FSD]]:** 코드를 Shared, Entities, Features, Widgets, Pages, App의 6가지 계층으로 분리하고, 상위 계층에서 하위 계층으로만 의존성이 흐르도록 제한합니다. 이 엄격한 단방향 의존성 규칙은 대규모 팀 협업 시 아키텍처의 유지보수성과 예측 가능성을 크게 높입니다 [7, 41, 42].
* **거버넌스와 자동화:** Uber는 UI 컴포넌트의 실제 사용 비율을 감지하는 옵저버빌리티 도구(Base Counter)와, [[Figma|Figma]] 콘솔 MCP를 이용해 AI 에이전트가 디자인 스펙 문서를 자동 생성하는 파이프라인을 구축해 대규모 디자인 시스템의 거버넌스와 확장성을 확보했습니다 [43-46].
## 🔗 Knowledge Connections
## 🔗 지식 연결 (Graph)
- **Related Topics:** [[Tailwind CSS|Tailwind CSS]], Styled-components, React Server Components (RSC, [[Compound Components|Compound Components]], Atomic Design, Design Tokens, [[Monorepo|Monorepo]], [[Feature-Sliced Design (FSD)|Feature-Sliced Design (FSD]]
- **Projects/Contexts:** [[Next.js 15 App Router|Next.js 15 App Router]], Kiwi.com Migration, Uber Base Web, [[Shopify Polaris|Shopify Polaris]]
- **Contradictions/Notes:** 소스에 따르면 Styled-components는 컴포넌트 단위의 동적 스타일링에 훌륭한 개발자 경험을 제공하지만 [8, 47], [[React Server Components (RSC)|React Server Components (RSC]]에서 Context 사용이 불가능하다는 구조적 한계와 런타임 성능 저하 문제로 인해 2025년 이후의 새로운 Next.js 프로젝트에서는 빌드 타임에 작동하는 Tailwind CSS, CSS Modules, 또는 [[Zero-Runtime CSS-in-JS|Zero-Runtime CSS-in-JS]]([[vanilla-extract|vanilla-extract]])의 사용이 강하게 권장됩니다 [4, 9, 10, 48].
---
*Last updated: 2026-04-26*
*Last updated: 2026-04-26*
## 🤖 LLM 활용 힌트 (How to Use This Knowledge)
**언제 이 지식을 쓰는가:**
- *(TODO)*
**언제 쓰면 안 되는가:**
- *(TODO)*
## 🧪 검증 상태 (Validation)
- **정보 상태:** needs_review
- **출처 신뢰도:** A
- **검토 이유:** *(P-Reinforce Phase 1 자동 정규화. 본문 검증 필요.)*
## 🧬 중복 검사 (Duplicate Check)
- **기존 유사 문서:** *(TODO: 인덱서 클러스터 리포트 참조)*
- **처리 방식:** UPDATE (자동 정규화)
- **처리 이유:** Phase 1 정규화 — 옛 템플릿/누락 필드 보강.
## ⚠️ 모순 및 업데이트 (Contradictions & Updates)
- **과거 데이터와의 충돌:** 없음
- **정책 변화:** 없음
## 🕓 변경 이력 (Changelog)
| 날짜 | 변경 내용 | 처리 방식 | 신뢰도 |
|------|-----------|-----------|--------|
| 2026-05-08 | P-Reinforce Phase 1 정규화 (frontmatter + 헤더 표준화) | UPDATE | A |
## 💻 코드 패턴 (Code Patterns)
**패턴 1:** *(TODO: 이 프로젝트 컨벤션 반영한 구조 스켈레톤)*
```text
# TODO
```
## 🤔 의사결정 기준 (Decision Criteria)
**선택 A를 써야 할 때:**
- *(TODO)*
**선택 B를 써야 할 때:**
- *(TODO)*
**기본값:**
> *(TODO)*
## ❌ 안티패턴 (Anti-Patterns)
- **[안티패턴]:** *(TODO: 무엇을 하면 안 되는가 + 이유 + 대신 무엇을)*