"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > CSS-in-JS 와 헤어지기

CSS-in-JS 와 헤어지기

2024-08-15에 게시됨
검색:421

CSS-in-JS

'CSS-in-JS'는 styled-components에서 시작된 흐름으로, Styling을 Javascript내부에서 정의한다.

styled-component, Emotion, Mantine 등이 있다.

장점

  1. 적용되는 스코프가 작다.
    1. css module 사용하면 css도 스코프를 줄일수 있음
  2. 컴포넌트와 같은 곳에 정의된다. (colocation)
  3. Javascript Variable 을 사용가능하다.

단점

  1. Runtime overhead가 있음
  2. Css in JS library 파일을 다운로드 받아야함.
    1. Emotion 은 7.9KB 이다.
    2. Mantine은 134KB!

엄청난 단점

  1. CSS 룰을 자주 집어 넣는것은 많은 계산 작업을 발생 시킨다.
    1. Emotion 과 Css 를 비교했더니
    2. Css사용시 약 50퍼정도의 성능 증가가 있었다.
  2. SSR을 쓸때 엄청 다양한 이슈를 발생시킨다
    1. Emotion 레포가보면 이슈가 많다.

실제 성능 비교

프로덕션에서 실제로 사용하는 코드를 사용해서 CSS-in-JS와 Tailwind를 비교해서 성능을 측정해보았다.

셋업

  • CSS-in-JS는 Mantine(Emotion 기반)을 사용한다.
  • 성능 측정은 React dev tool을 사용한다.
  • 성능 측정 대상은 30 * 5의 Table(컴포넌트 이름: SheetTable)이다.

화면

CSS-in-JS 와 헤어지기

실험 진행

  • 버튼을 누르면 위의 화면이 랜더링 된다.
  • React Profiler의 녹화를 키고 버튼을 눌러서 화면 랜더링을 녹화한다.
  • SheetTable의 랜더링 시간을 측정한다.
  • 총 5번씩 수행하여 평균을 구한다.

CSS-in-JS (Mantine)

CSS-in-JS 와 헤어지기

Tailwind

CSS-in-JS 와 헤어지기

결과

  • 약 36퍼의 rendering 시간 감소를 보였다.
  • 셀 코드 하나 바꾼 것인데도 성능 향상이 컸다. (물론 셀이 대부분이긴함)
  • 60Hz 모니터에서 1 프레임이 16ms인데 3frame -> 2frame 이 된것

CSS-in-JS 와 헤어지기

결론

  • Static하게 생성되는 CSS 사용하는게 성능면에서 꽤 많이 좋다.
  • JS 변수를 사용해야하는 경우가 아니라면 Tailwind를 쓰자.
  • (추가)SSR을 도입하려면 CSS-in-JS를 버리는게 편하다.
Ref

[1] https://dev.to/srmagura/why-were-breaking-up-wiht-css-in-js-4g9b

릴리스 선언문 본 글은 https://dev.to/siisee11/css-in-js-wa-heeojigi-1pbj?1 에서 복제하였습니다. 침해 내용이 있는 경우, [email protected]으로 연락하여 삭제해 주시기 바랍니다.
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3