Files
2nd/10_Wiki/Topics/Dynamic Theming.md
T

4.3 KiB

Dynamic Theming

📌 Brief Summary

Dynamic Theming(동적 테마 적용)은 라이트 모드/다크 모드 또는 다중 브랜드 테마와 같이 사용자 설정이나 컨텍스트에 따라 UI의 시각적 속성을 런타임에 유연하게 전환할 수 있는 기법입니다. 이는 주로 디자인 토큰(Design Tokens), CSS 변수(Custom Properties), 또는 styled-components와 같은 CSS-in-JS 라이브러리를 활용하여 구현됩니다. 컴포넌트 코드의 직접적인 수정 없이 애플리케이션 전체의 디자인 시스템을 일관성 있고 확장 가능하게 관리하는 데 필수적인 역할을 합니다.

📖 Core Content

  • 디자인 토큰 기반의 테마 전환 (Token Swapping): 동적 테마 구현의 핵심은 단일 소스인 디자인 토큰을 활용하는 것입니다. 특정 시맨틱 토큰(Semantic Token)이 테마에 따라 다른 참조 값(Reference Value)을 가리키도록 설정합니다(예: 라이트 모드에서는 color.background = ref.gray.100, 다크 모드에서는 ref.gray.900) [1]. Style Dictionary와 같은 도구를 활용하면 Figma 등에서 정의된 JSON 형식의 토큰을 CSS 변수나 React 테마 객체로 자동 변환하여 손쉽게 테마 전용 출력물을 생성할 수 있습니다 [2-4].
  • CSS 변수(CSS Variables)를 활용한 동적 테마: 최적의 성능을 위해 디자인 토큰을 CSS 변수에 매핑하여 사용하는 방식이 널리 쓰입니다 [5]. 테마별로 별도의 토큰 세트를 정의하고(예: light-theme.css, dark-theme.css), 런타임 시에 <html> 또는 <body> 같은 최상위 컨테이너에 테마 클래스를 토글하여 스타일을 업데이트할 수 있습니다 [5, 6]. 이 접근법은 값비싼 전체 리렌더링(full re-render)을 유발하지 않아 부드럽고 빠른 사용자 경험을 제공합니다 [5, 7]. 최근 Tailwind CSS v4에서도 @theme 디렉티브와 CSS 변수를 활용해 네이티브 수준의 런타임 테마 전환을 직관적으로 지원합니다 [8, 9].
  • React 프레임워크 및 CSS-in-JS의 테마 적용: styled-componentsEmotion 같은 CSS-in-JS 라이브러리는 기본적으로 제공하는 ThemeProvider를 사용해 React 컴포넌트 트리에 동적으로 테마를 주입할 수 있어 다중 테마 구현에 매우 용이합니다 [10, 11]. 또한, Chakra UI는 CSS-in-JS를 기반으로 제작되어 런타임 시 라이트/다크 모드 동적 전환을 쉽게 구현할 수 있도록 돕습니다 [12].
  • React Server Components (RSC) 환경에서의 제약과 해법: Context 기반의 ThemeProvider는 React Context가 없는 서버 컴포넌트(RSC) 환경에서는 작동하지 않는 근본적인 한계가 있습니다 [13-15]. 이를 해결하기 위해 styled-components (v6.4 이상)는 createTheme 함수를 도입하여 일반 테마 객체를 CSS 사용자 정의 속성 참조(예: var(--prefix-path))로 변환합니다 [13]. 이 방식은 React Context에 의존하지 않으므로 클라이언트와 서버 컴포넌트 모두에서 동작하며, 라이트/다크 모드 전환 시 하이드레이션(Hydration) 불일치나 화면 깜빡임(Flash)을 방지합니다 [13, 16].

🔗 Knowledge Connections

  • Related Topics: Design Tokens, CSS Variables, Styled Components, Tailwind CSS, React Server Components (RSC)
  • Projects/Contexts: Scalable Frontend Systems, Component Library Architecture, Design-to-Code Workflow
  • Contradictions/Notes: CSS-in-JS 라이브러리의 ThemeProvider는 동적인 테마 적용에 매우 유용하지만, Next.js의 App Router와 같은 React Server Components(RSC) 아키텍처와는 본질적으로 호환되지 않습니다 [14, 15]. 최신 확장성 높은 프론트엔드 환경에서는 이러한 런타임 CSS-in-JS 대신 정적 생성된 CSS 변수나 Tailwind CSS, 혹은 제로 런타임 라이브러리(vanilla-extract) 기반의 테마 시스템을 구축하는 것이 권장됩니다 [13, 15, 17, 18].

Last updated: 2026-04-26