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,16 +1,29 @@
---
category: Unified
id: wiki-2026-0508-large-frontend-projects
title: Large Frontend Projects
category: 10_Wiki/Topics
status: needs_review
canonical_id: self
aliases: []
duplicate_of: none
source_trust_level: A
confidence_score: 0.92
tags: [auto-consolidated, technical-documentation]
title: [[Large Frontend Projects|Large Frontend Projects]]
last_updated: 2026-05-02
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
---
# [[Large Frontend Projects|Large Frontend Projects]]
## 📌 Brief Summary
## 📌 한 줄 통찰 (The Karpathy Summary)
대규모 프론트엔드 프로젝트는 수백 개의 컴포넌트, 다수의 협업 팀, 동적 상태 관리, 재사용 가능한 디자인 시스템 등이 결합된 엔터프라이즈급 웹 애플리케이션을 의미합니다 [1]. 이러한 프로젝트가 확장됨에 따라 CSS는 단순한 시각적 장식이 아닌 아키텍처의 무결성과 장기적인 유지보수성을 요구하는 엄격한 엔지니어링 영역으로 전환되었습니다 [2]. 전역 네임스페이스 충돌이나 'CSS 비대화(Bloat)'를 방지하기 위해 BEM, [[CSS Modules|CSS Modules]], [[Tailwind CSS|Tailwind CSS]]와 같은 구조화된 스타일링 방법론과 기능 중심(Feature-Driven)의 폴더 구조 도입이 필수적입니다 [1-4].
## 📖 Core Content
## 📖 구조화된 지식 (Synthesized Content)
* **대규모 프로젝트에서의 CSS 엔지니어링 문제**
대규모 시스템에서는 CSS가 전역적으로 적용된다는 특성 때문에 예기치 않은 스타일 덮어쓰기(Overrides), 선택자 특이성(Specificity) 충돌, 중복 스타일, 그리고 새로운 개발자의 온보딩 지연 등의 문제가 발생합니다 [1, 5]. 이는 개발 생산성과 장기적인 확장성에 직접적인 악영향을 미치므로, CSS를 단순한 데코레이션 레이어가 아닌 엄격한 엔지니어링 규율로 접근해야 합니다 [2, 5].
@@ -37,10 +50,10 @@ last_updated: 2026-05-02
* **확장 가능한 폴더 구조 및 아키텍처:** [[Next.js|Next.js]]와 같은 대규모 환경을 장기적으로 유지보수하기 위해서는 파일의 유형(컴포넌트, 훅 등)별로 코드를 분리하는 대신 실제 도메인에 기반한 '기능 중심(Feature-Driven 또는 Domain-Driven) 아키텍처'를 채택해야 합니다 [3, 13]. 특정 기능 디렉토리 내에 컴포넌트와 연관된 스타일을 함께 배치(co-locate)하면, 기능이 제거될 때 스타일도 자동 폐기되어 레거시 코드베이스에 '유령 스타일(ghost styles)'이 축적되는 것을 방지할 수 있습니다 [4, 14].
* **디자인 시스템과 디자인 토큰 적용:** 다수의 제품 팀과 여러 플랫폼(Web, iOS, Android)에 걸쳐 일관성을 유지하기 위해 디자인 토큰(Global, Alias, Component 계층) 관리가 필요합니다 [15-18]. JSON 포맷 등으로 저장된 토큰 데이터를 변환 도구를 통해 각 플랫폼의 코드로 자동 배포함으로써 '단일 진실 공급원([[Single_Source_of_Truth|Single Source of Truth]])'을 구축하고 인적 오류를 차단할 수 있습니다 [17, 19].
## Trade-offs & Caveats
## 모순 및 업데이트 (Contradictions & Updates)
No trade-offs available.
## 🔗 Knowledge Connections
## 🔗 지식 연결 (Graph)
- **Related Topics:** [[CSS 구조 설계 방식|CSS 구조 설계 방식]], BEM, CSS Modules, Tailwind 전략, [[디자인 시스템 개념|디자인 시스템 개념]], [[Feature-Sliced Design|Feature-Sliced Design]]
- **Projects/Contexts:** 대규모 엔터프라이즈 플랫폼 개발, 컴포넌트 기반 프레임워크(React, Vue 등) 환경의 협업
- **Contradictions/Notes:** Tailwind CSS의 유틸리티 클래스 방식은 빌드 크기를 최적화하고 일관된 디자인 시스템 적용에 뛰어나 대규모 프로젝트에 이상적이라는 주장이 있습니다 [23, 24]. 그러나 과도하게 길어지는 클래스명으로 인해 HTML 가독성이 떨어지고 컴포넌트 유지보수가 힘들어질 수 있다는 반론도 존재합니다 [36, 37]. 이 때문에 대규모 환경에서는 전역 레이아웃 및 디자인 토큰에는 Tailwind를, 세밀하고 복잡한 스타일 제어에는 CSS Modules 또는 SCSS를 결합하는 하이브리드 방식이 실무적 타협안으로 제시되고 있습니다 [26, 27, 38]. BEM 역시 유용하나 인적 오류로 인한 한계 때문에 점차 CSS Modules나 Zero-runtime [[CSS-in-JS|CSS-in-JS]] 같은 자동화 캡슐화 툴로 대체되는 경향을 보입니다 [18, 21, 39].
@@ -59,4 +72,53 @@ No trade-offs available.
## 📌Brief 대요
대규모 프론트엔드 프로젝트(Large Frontend Projects)란 수백 개의 컴포넌트, 동적인 상태 관리, 재사용 가능한 디자인 시스템을 포함하며 다수의 개발 팀이 동시에 참여하는 복잡한 규모의 애플리케이션을 의미합니다 [1]. 이러한 프로젝트에서는 UI를 단순히 "예쁘게" 렌더링하는 것을 넘어, 다수 개발자의 협업과 지속적인 반복 작업, 기술 부채의 축적을 견뎌낼 수 있는 견고한 아키텍처적 무결성과 유지보수성이 핵심 목표가 됩니다 [2]. 따라서 전역 네임스페이스 충돌이나 '스파게티 스타일(spaghetti styles)'과 같은 CSS 비대화(CSS bloat) 현상을 방지하기 위해 BEM, [[CSS Modules|CSS Modules]], [[Tailwind CSS|Tailwind CSS]] 등과 같은 체계적인 CSS 아키텍처와 명확한 폴더 구조 설계가 필수적입니다 [1-4].
대규모 프론트엔드 프로젝트(Large Frontend Projects)란 수백 개의 컴포넌트, 동적인 상태 관리, 재사용 가능한 디자인 시스템을 포함하며 다수의 개발 팀이 동시에 참여하는 복잡한 규모의 애플리케이션을 의미합니다 [1]. 이러한 프로젝트에서는 UI를 단순히 "예쁘게" 렌더링하는 것을 넘어, 다수 개발자의 협업과 지속적인 반복 작업, 기술 부채의 축적을 견뎌낼 수 있는 견고한 아키텍처적 무결성과 유지보수성이 핵심 목표가 됩니다 [2]. 따라서 전역 네임스페이스 충돌이나 '스파게티 스타일(spaghetti styles)'과 같은 CSS 비대화(CSS bloat) 현상을 방지하기 위해 BEM, [[CSS Modules|CSS Modules]], [[Tailwind CSS|Tailwind CSS]] 등과 같은 체계적인 CSS 아키텍처와 명확한 폴더 구조 설계가 필수적입니다 [1-4].
## 🤖 LLM 활용 힌트 (How to Use This Knowledge)
**언제 이 지식을 쓰는가:**
- *(TODO)*
**언제 쓰면 안 되는가:**
- *(TODO)*
## 🧪 검증 상태 (Validation)
- **정보 상태:** needs_review
- **출처 신뢰도:** A
- **검토 이유:** *(P-Reinforce Phase 1 자동 정규화. 본문 검증 필요.)*
## 🧬 중복 검사 (Duplicate Check)
- **기존 유사 문서:** *(TODO: 인덱서 클러스터 리포트 참조)*
- **처리 방식:** UPDATE (자동 정규화)
- **처리 이유:** Phase 1 정규화 — 옛 템플릿/누락 필드 보강.
## 🕓 변경 이력 (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: 무엇을 하면 안 되는가 + 이유 + 대신 무엇을)*