CDD (component-Driven Dvelopment)
- CDD를 사용하면 부품 단위로 UI 컴포넌트를 만들어 나가는 개발을 진행할 수 있다.
- 이렇게 하면 여러 프로젝트 간에 같은 UI 컴포넌트를 사용할 수 있다. (재사용할 수 있는 UI 컴포넌트!)
기술의 발달에 따라 CSS를 작성하는 방식 또한 꾸준히 진화해오고 있다. (마치 인류의 진화 과정처럼!)
문제점 1 : CSS 작성에 있어 일관된 패턴이 없어 작성이 효율적이지 않다!
-> 진화 1 : CSS 구조화 (CSS 전처리기)
- CSS 작성 시 요구되는 많은 반복적 작업 (color 찾기, tag 닫기 등등 ) -> 프로그래밍 개념 (변수, 함수, 상속) 사용해 해결!
- CSS 전처리기 사용시 이에 맞는 컴파일러 사용해야 우리가 사용하는 CSS 문서로 변환이 됨.
대표적 예시 : SASS (Syntactically Awesome Style Sheets)
- CSS를 만들어주는 언어
- JS처럼 특정 속성 (color, margin...)의 값을 변수로 선언해 필요한 곳에 사용 가능
- 반복되는 코드를 한 번의 선언으로 여러 곳에서 재사용 가능하게 함
- 단점 : 전처리 과정이 필요하며, 컴파일한 CSS 파일의 용량이 커진다, 언어 로직상 진정한 캡슐화의 개념이 없다. (실제 구현 내용을 외부로부터 은닉 X)
문제점 2 : CSS 전처리기를 사용하면 전처리 과정이 필요하며 CSS 파일의 용량이 거대해진다!
-> 진화 2 : BEM, OOCSS, SMACSS 와 같은 CSS 방법론이 방법론들은 공통적으로 다음과 같은 지향점을 가짐
- 코드의 재사용
- 코드의 간결화
- 코드의 확장성
- 클래스명으로 의미 예측 가능
대표적 예시 : BEM (Block, Element, Modifier)
- 이름 그대로 Block, Element, Modifier 세 가지로 구분하여 클래스 명을 작성하는 방식 (각각 -와 _으로 구분함)
- 클래스면 재사용 가능 -> 일관된 코딩 구조를 만들어줌
- 단점: 클래스명이 너무 길어지며, 클래스 목록이 너무 많아짐, 언어 로직상 진정한 캡슐화의 개념이 없음
문제점 3 : BEM의 네이밍 문제와 CSS 전처리기, BEM의 캡슐화 문제!
-> 진화 3 : CSS-in-JS
- CSS를 컴포넌트 기반으로 작성할 수 있게 도와주는 라이브러리
- JS 파일 안에서 HTML + JS + CSS 를 하나로 묶어 컴포넌트 단위로 개발할 수 있게 됨
- 위의 모든 문제점을 해결하는 방식!
대표적 예시 : Styled-Components
- CSS-in-JS 중에서 가장 널리 사용되고 있는 라이브러리
- 단점 : 빠른 페이지 로드에 불리함
그렇다면 CSS를 컴포넌트의 영역으로 불러들여 위의 모든 문제점을 해결한 Styled-Component 라이브러리에 대해서 배워보자.
$ npm install --save styled-components
터미널에 다음과 같은 명령어를 입력해 Styled-Components 를 설치해준다.
import styled from "styled-components"
그 후 styled component 를 사용할 파일로 import 해준다.
- 기본 문법
const 컴포넌트이름 = styled.태그종류` CSS속성1 : 속성값; CSS속성2 : 속성값; `;
- 컴포넌트 재활용
const 컴포넌트이름 = styled(재활용할 컴포넌트)` 추가할 CSS속성1 : 속성값; 추가할 CSS속성2 : 속성값; `
- Props 활용
// 기본문법 const 컴포넌트이름 = styled.태그종류` CSS속성 : ${(props) => 함수 코드} `; // 삼항 연산자 사용해 조건부 렌더링 const 컴포넌트이름 = styled.태그종류` CSS속성 : ${(props) => props.value값 ? 속성값 : 속성값 } `; // Props 값 통째로 활용해 렌더링 const 컴포넌트이름 = styled.태그종류` CSS속성 : ${(props) => props.value값 ? props.value값 : 속성값} `;
- 전역 스타일 설정
//import import { createGlobalStyle } from "styled-components"; // 전역 스타일 설정 const GlobalStyle = createGlobalStyle` 설정해주고 싶은 스타일 작성하기 `; // 이렇게 코드 작성한 후 이 컴포넌트를 최상위 컴포넌트에서 사용해주면 적용이 됨 <GlobalStyle />