JS의 CSS: 더욱 깔끔하고 확장 가능한 스타일을 위한 Styled-Components, Emotion 등에 대한 완벽한 가이드입니다.

Susan Sarandon
풀어 주다: 2024-11-26 06:45:12
원래의
194명이 탐색했습니다.

CSS in JS: Complete guide to Styled-Components, Emotion and more for cleaner and scalable styling.

복잡하고 방대한 CSS 파일을 다루거나 대규모 프로젝트에서 스타일을 체계적으로 유지하는 데 어려움을 겪은 적이 있다면 JS의 CSS가 마음에 드실 것입니다. 이 접근 방식을 사용하면 JavaScript 내부에 CSS를 직접 작성할 수 있기 때문에 스타일이 모듈화되고 유연해지며 React와 같은 구성 요소 기반 프레임워크에 완벽하게 들어맞습니다.

가장 인기 있는 두 가지 CSS-in-JS 라이브러리인 Styled-Components와 Emotion을 살펴보고 이를 효과적으로 사용하는 방법에 대한 실용적인 팁을 제공하겠습니다.

깨끗하고 유지 관리 및 확장 가능한 코드를 희생하지 않고도 이 도구가 어떻게 스타일을 변경할 수 있는지 자세히 살펴보겠습니다.

왜 CSS-in-JS인가요?
JS의 CSS가 인기를 얻는 이유 중 하나는 특히 대규모 애플리케이션을 구축하는 팀의 경우 최신 웹 개발의 가장 큰 과제 중 하나를 해결하기 때문입니다. JavaScript 내부에서 스타일을 이동하여 다음을 달성합니다.

범위 지정 스타일: 더 이상 클래스 이름 충돌이 없습니다. 각 구성 요소에 적용되는 스타일.

동적 스타일링: JavaScript 로직을 사용하여 소품, 테마 또는 애플리케이션 상태와 관련된 스타일을 변경합니다.

컴포넌트 기반 개발: CSS-in-JS 라이브러리는 자연스럽게 React, Vue 및 Angular와 같은 컴포넌트 기반 프레임워크와 함께 사용됩니다. 그러면 스타일이 캡슐화되고 모듈화됩니다.

스타일 구성요소: 기본
Styled-Components는 아마도 CSS-in-JS 생태계에서 가장 인기 있는 라이브러리 중 하나이며, 단순성을 자랑하고 React와 함께 사용하기 쉽습니다.

빠른 시작
스타일 구성 요소 설치:
$ npm 스타일 구성 요소 설치
그런 다음 구성 요소로 가져옵니다.
$ '스타일 구성 요소'에서 스타일 가져오기;

스타일이 지정된 구성요소:

const 버튼 = styled.button`
배경색: #6200ea;
색상: 흰색;
패딩: 10px 20px;
테두리 반경: 5px;
테두리: 없음;
커서: 포인터;

&:hover {
배경색: #3700b3;
}
JSX에서 스타일이 지정된 구성 요소를 사용하세요.

나를 클릭하세요

주요 기능:
테마화: Styled-Components를 사용하면 애플리케이션 전반에 걸쳐 일관된 스타일을 위한 테마를 만들 수 있습니다.

동적 스타일링: 동적으로 스타일을 지정하는 방법을 변경하고 싶을 수도 있습니다. 이는 소품과 함께 사용되어 매우 유연하고 재사용 가능한 구성 요소를 만들 수 있습니다.

감성: 유연성과 성능
또 다른 강력한 CSS-in-JS 라이브러리는 유연성과 성능으로 유명한 Emotion입니다. 인라인 스타일의 경우 CSS Prop, 스타일은 재사용 가능한 구성 요소의 두 가지 주요 스타일링 방법을 제공합니다.

빠른 시작
감정 설치:

npm install @emotion/react @emotion/styled
가져오기 및 사용:

'@emotion/styled'에서 스타일 가져오기;

const 카드 = styled.div`
패딩: 20px;
상자 그림자: 0 4px 8px rgba(0, 0, 0, 0.2);
테두리 반경: 8px;
배경색: 흰색;

동적 인라인 스타일의 경우:

'@emotion/react'에서 { CSS } 가져오기;

const DynamicStyle = css`
색상: 파란색;
글꼴 크기: 16px;

안녕하세요 이모션!

주요 기능:
인라인 및 재사용 가능한 스타일: Emotion의 CSS 및 스타일 API를 통해 스타일링 방법을 통해 더 많은 제어력과 유연성을 얻을 수 있습니다.

서버 측 렌더링: Emotion은 SSR에 고도로 최적화되어 있으므로 SEO에 대한 뛰어난 성능이 필요한 애플리케이션에서 완벽한 사용 사례를 찾습니다.

CSS-in-JS 모범 사례
성능을 유지하고 스타일을 깔끔하게 유지하는 데 도움이 되는 CSS-in-JS를 효과적으로 사용하기 위한 몇 가지 모범 사례가 있습니다.

너무 많은 인라인 동적 스타일 피하기: 인라인 스타일은 일회성 사소한 조정에 적합합니다. 그러나 너무 많으면 성능에 병목 현상이 발생합니다. 대신 재사용 가능한 스타일을 위해 스타일이 지정된 구성요소를 적용하고 인라인 스타일을 꼭 필요한 경우로 제한하세요.

테마 활용: 테마를 사용하여 일관된 구조를 적용하고 애플리케이션을 살펴보세요. Styled-Components 및 Emotion과 같은 라이브러리를 사용하면 전역 테마를 정의할 수 있습니다. 이렇게 하면 구성 요소 전체에 브랜딩 색상, 글꼴 및 기타 스타일 기준을 훨씬 쉽게 적용할 수 있습니다.

'스타일 구성요소'에서 { ThemeProvider } 가져오기;

const 테마 = {
기본색상: '#6200개',
글꼴 크기: '16px',
};

Prop 기반 스타일: 동적 Prop을 사용하면 구성 요소 상태나 수신 데이터에 따라 스타일을 변경할 수 있습니다. Styled-Components와 Emotion 모두에서 소품은 스타일을 다시 작성하지 않고도 구성 요소가 다양한 사용 시나리오의 요구 사항을 충족할 수 있는 간단한 방법을 제공합니다.

const 버튼 = styled.button`
배경색: ${(props) => (props.primary ? '#6200ea' : '#eee')};
색상: ${(props) => (props.primary ? 'white' : 'black')};

기본 버튼
보조버튼

코드 분할: 주의하지 않으면 CSS-in-JS 라이브러리로 인해 더 큰 묶음이 생성될 수 있다는 점에 유의하세요. 적절한 성능을 보려면 코드 분할과 같은 기술을 활용하고 앱의 각 부분에 필요한 스타일만 로드하세요.

스타일-컴포넌트 vs 감성
어느 것을 사용할 것인가? 둘 다 놀라운 라이브러리이며 각각 다른 요구 사항을 충족합니다. 빠른 비교:

스타일 구성 요소: 테마 지정 및 사용 편의성이 필요한 React 애플리케이션에 가장 적합합니다. 채택률이 높고 문서도 매우 우수하여 초보자에게 친숙합니다.

감정: 더욱 유연하고 성능에 최적화되었습니다. SSR 지원이 필요하거나 인라인 및 재사용 가능한 스타일링 옵션을 모두 제공하는 라이브러리를 찾는 경우 Emotion이 가장 적합합니다.

CSS-in-JS는 특히 구성 요소 중심 프레임워크를 사용하는 개발자인 경우 현대적인 웹 스타일을 수행하는 강력한 방법을 나타냅니다. Styled-Components 및 Emotion과 같은 라이브러리를 사용하면 애플리케이션 전체에서 스타일을 모듈식, 동적 및 일관성으로 유지할 수 있습니다.

모범 사례 범위의 인라인 스타일, 테마 활용, prop 중심 스타일을 가까이 유지함으로써 CSS-in-JS를 최대한 활용하여 코드를 정리하고 확장할 수 있습니다.

CSS 작업 방식을 바꿀 준비가 되셨나요? CSS-in-JS를 직접 사용해 보세요!

위 내용은 JS의 CSS: 더욱 깔끔하고 확장 가능한 스타일을 위한 Styled-Components, Emotion 등에 대한 완벽한 가이드입니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿