css scope, scope 무시하기

2024. 9. 22. 23:33· 프론트엔드
목차
  1. css scope
  2. scope 예외

css scope

기본적으로 css는 전역으로 적용된다.

그러나 css scoping을 하면, 해당 컴포넌트 내에서만 한정적으로 적용할 수 있게 된다.

css 범위를 해당 컴포넌트로 제한하여, 컴포넌트간 스타일 충돌을 방지할 수 있다.

 

스코핑 결과

          css scoping 적용하면 컴포넌트별로 랜덤한 접두사가 붙는다.



html 요소에는 고유한 랜덤 접두사가 추가되고, css에는 접두사가 포함된 셀렉터로 변환된다.
만약, 두 컴포넌트에서 동일한 클래스명을 쓰더라도 서로 다른 접두사가 추가되어 서로 충돌나지 않는다.



scope 예외

그러나 외부 UI라이브러리를 쓰다보면 scoping을 무시해야 할 때가 있다.

전역에서 하위 컴포넌트에 설정되있는 스타일을 직접 바꿔서 처리해야 하는 경우가 발생하곤 한다.

 

그럴 경우 vue에서는 ::v-deep 또는 :global 선택자를, vite에선  :global 선택자를 사용하여 

css scoping을 무시할 수 있다.

 

 

스코핑 예외 처리 결과

.children은 이제 스코핑이 무시되어 랜덤한 접두사 같은것이 붙지 않고

그냥 순수 css처럼 되어 전역에 미치게 된다.


  • Vue (프레임워크)
    : 뷰 프레임워크가 기본적으로 제공한다. vue-loader를 통해 css module 기능을 사용하게 된다.
  • React (라이브러리)
    : vite 같은 번들러를 따로 설치해야 한다. vite에서 css module 기능을 제공해준다.


https://github.com/css-modules/css-modules/blob/master/docs/composition.md#exceptions

 

https://stackoverflow.com/questions/43613619/what-does-global-colon-global-do

'프론트엔드' 카테고리의 다른 글

React-Query 사용기  (0) 2024.10.20
FTP와 SFTP에 대해, RSA에 대해  (0) 2024.10.04
Axios interceptor  (1) 2024.08.10
📍피그마와 브라우저간 폰트 차이나는 현상  (0) 2024.05.20
외부 CDN의 위험성  (0) 2024.05.02
  1. css scope
  2. scope 예외
'프론트엔드' 카테고리의 다른 글
  • React-Query 사용기
  • FTP와 SFTP에 대해, RSA에 대해
  • Axios interceptor
  • 📍피그마와 브라우저간 폰트 차이나는 현상
journey-dev
journey-dev
journey-dev
journey-dev
journey-dev
전체
오늘
어제
  • 분류 전체보기 (63)
    • 프론트엔드 (44)
      • JS (8)
      • React (8)
      • vue (9)
      • Typescript (2)
    • CS (0)
      • 자료구조&알고리즘 (2)
      • 네트워크 (2)
    • 개발서적 (1)
      • 코어 자바스크립트 (0)
      • 프론트엔드 성능 최적화 가이드 (1)
    • DB (11)
      • SQL (11)
    • GIT (0)
    • GIS (3)
    • 개발일기 (0)
    • ing (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

  • 일단 시작해라. 나중에 완벽해지면 된다.

인기 글

태그

  • 리액트 복기하기!

최근 댓글

최근 글

hELLO · Designed By 정상우.v4.2.2
journey-dev
css scope, scope 무시하기
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.