> 웹 프론트엔드 > CSS 튜토리얼 > CSS 범위가 지정된 사용자 정의 속성은 상속 및 재정의를 어떻게 처리합니까?

CSS 범위가 지정된 사용자 정의 속성은 상속 및 재정의를 어떻게 처리합니까?

Patricia Arquette
풀어 주다: 2024-12-19 04:37:26
원래의
904명이 탐색했습니다.

How Do CSS Scoped Custom Properties Handle Inheritance and Overriding?

CSS 범위 사용자 정의 속성: 범위 및 상속 이해

CSS 사용자 정의 속성을 정의할 때 원하는 효과를 얻으려면 범위를 이해하는 것이 중요합니다. 요소 내에 선언된 사용자 정의 속성의 범위는 해당 요소와 해당 하위 항목으로 지정됩니다. 그러나 이 범위 지정은 이 질문에 설명된 것처럼 때로는 예상치 못한 동작으로 이어질 수 있습니다.

제공된 코드에서 사용자 정의 속성 --scale이 루트 수준에서 정의된 다음 재정의된다는 사실에서 문제가 발생합니다. 하위 요소 내에서. 범위가 지정된 사용자 정의 속성을 사용할 때는 이러한 재정의 동작이 예상되지 않습니다.

이 문제를 설명하기 위해 CSS를 분석해 보겠습니다.

:root {
  --size-1: calc(1 * var(--scale, 1) * 1rem);
  --size-2: calc(2 * var(--scale, 1) * 1rem);
  --size-3: calc(3 * var(--scale, 1) * 1rem);
}

.scale-1x {
  --scale: 1;
}

.scale-2x {
  --scale: 2;
}

.scale-3x {
  --scale: 3;
}
로그인 후 복사

여기서 --size-* 속성은 값에 따라 달라집니다. --scale. 그러나 .scale-1x, .scale-2x 및 .scale-3x 클래스 내에서 --scale을 정의하면 :root에 정의된 값이 재정의됩니다.

예상되는 동작은 -- 정의된 각 요소에서 scale 속성을 평가해야 하므로 각 목록의 글꼴 크기가 달라집니다. 그러나 사용자 정의 속성이 이미 루트 수준에서 평가되었기 때문에 이런 일이 발생하지 않습니다.

이 문제를 해결하고 원하는 효과를 얻으려면 범위가 지정된 사용자 정의 속성을 보다 일관되게 사용하는 것이 좋습니다. 예를 들어 각 .scale-* 클래스 내에서 --size-1, --size-2 및 --size-3을 정의하여 해당 요소로만 범위가 지정되도록 합니다. 이렇게 하면 해당 클래스 내에 정의된 --scale 값을 기반으로 각 목록의 독립적인 크기 조정이 가능해집니다.

위 내용은 CSS 범위가 지정된 사용자 정의 속성은 상속 및 재정의를 어떻게 처리합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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