Files
2nd/10_Wiki/Topics_Dev/Atomic Design.md
T

4.7 KiB

Atomic Design

📌 Brief Summary

Atomic Design(아토믹 디자인)은 브래드 프로스트(Brad Frost)가 고안한 디자인 방법론으로, 사용자 인터페이스(UI)를 응집력 있는 전체이자 부분의 집합으로 동시에 생각할 수 있게 해주는 멘탈 모델입니다 [1-3]. 이 방법론은 인터페이스를 원자(Atoms), 분자(Molecules), 유기체(Organisms), 템플릿(Templates), 페이지(Pages)라는 5개의 계층적 단계로 나누어 효과적이고 의도적인 디자인 시스템을 구축하도록 돕습니다 [4, 5]. React와 같은 모던 컴포넌트 아키텍처와 결합하여 일관성을 강제하고, 디자인 시스템의 재사용성을 높이며, 확장 가능한 폴더 구조를 구축하는 데 널리 활용됩니다 [6-8].

📖 Core Content

  • 5단계의 컴포넌트 계층 구조:

    • 원자 (Atoms): 더 이상 쪼갤 수 없는 UI의 기본 구성 요소입니다 [1, 5]. HTML 태그(예: input, label, button)나 React의 기본 함수형 컴포넌트에 해당하며, 각기 고유한 속성을 가집니다 [9, 10].
    • 분자 (Molecules): 원자들의 결합으로 이루어진 비교적 단순한 UI 컴포넌트 그룹입니다(예: 라벨 + 입력창 + 버튼 = 검색 폼) [5, 10, 11]. 단일 책임 원칙(Single Responsibility Principle)을 장려하여 "한 가지 일을 잘 수행하도록" 함으로써 테스트와 재사용성을 용이하게 합니다 [12].
    • 유기체 (Organisms): 분자, 원자, 혹은 다른 유기체들로 구성된 복잡한 컴포넌트로, 인터페이스의 뚜렷한 독립적 섹션을 형성합니다(예: 웹사이트 헤더, 제품 그리드) [5, 10, 13, 14].
    • 템플릿 (Templates): 컴포넌트들을 레이아웃에 배치하고 디자인의 근본적인 콘텐츠 구조(뼈대)를 명확히 하는 페이지 레벨의 객체입니다 [5, 10, 15, 16]. 최종 콘텐츠보다는 기본 골격에 집중합니다 [16].
    • 페이지 (Pages): 템플릿에 실제 대표 콘텐츠를 주입한 구체적 인스턴스입니다. 최종 UI를 보여주고 기초 디자인 시스템의 효과와 복원력을 테스트하며 콘텐츠의 동적 변형(예: 데이터 길이에 따른 변화)을 명확히 합니다 [5, 10, 17-19].
  • Atomic Design의 핵심 이점 및 특징:

    • 맥락의 전환: 추상적인 요소(원자)를 조작하는 동시에 그것들이 모여 구체적인 최종 결과물(페이지)에 미치는 영향을 빠르게 파악하고 테스트할 수 있도록 돕습니다 [20, 21].
    • 구조와 콘텐츠의 분리: UI의 콘텐츠 구조 스켈레톤(템플릿)과 최종 콘텐츠(페이지) 사이의 깔끔한 분리를 제공하면서도 둘의 상호작용을 고려하게 합니다 [22, 23].
    • 보편적 적용성: 웹 전용 기술(CSS, JavaScript 구조 등)에 국한되지 않으며, Instagram과 같은 네이티브 모바일 앱을 포함한 모든 소프트웨어 인터페이스 설계에 적용할 수 있습니다 [24-26].
    • 비선형적 접근: 단순히 1단계에서 5단계로 순차적으로 진행하는 선형 프로세스가 아니라, 전체와 부분을 동시에 설계하기 위한 멘탈 모델로 접근해야 합니다 [1, 2].
  • React 확장성 및 아키텍처에서의 활용:

    • React의 컴포넌트 트리와 완벽하게 대칭을 이루어 디자인 시스템을 구축하는 근본적인 모델이 됩니다 [6].
    • 성공적인 엔터프라이즈 팀들은 원자 단위의 순수함과 재사용성을 유지하기 위해 UI 라이브러리 계층에는 Atomic Design을 활용하고, 비즈니스 로직이 들어가는 애플리케이션 코드에는 기능 분할 설계(Feature-Sliced Design, FSD) 등 기능 기반 구조를 혼합하여 설계합니다 [10, 27].

🔗 Knowledge Connections

  • Related Topics: Component-Based Design, Feature-Sliced Design (FSD), Compound Components, Design Systems
  • Projects/Contexts: React Frontend Architecture, Reusable UI Component Libraries
  • Contradictions/Notes: 소스에 따르면 Atomic Design은 시각적 일관성과 재사용성을 달성하는 데는 매우 강력하지만, 복잡한 비즈니스 로직을 가진 컴포넌트를 이 5가지의 엄격한 범주에 억지로 끼워 맞추려다 보면 어려움에 직면할 수 있다는 한계도 지적됩니다 [10]. 이에 대한 보완책으로 Headless UICompound Components 패턴이 현대 프론트엔드 환경에서 함께 권장됩니다 [28, 29].

Last updated: 2026-04-26