> 웹 프론트엔드 > CSS 튜토리얼 > 외부 범위 계산에 사용될 때 범위가 지정된 CSS 사용자 정의 속성이 무시되는 이유는 무엇입니까?

외부 범위 계산에 사용될 때 범위가 지정된 CSS 사용자 정의 속성이 무시되는 이유는 무엇입니까?

Susan Sarandon
풀어 주다: 2024-12-22 02:51:20
원래의
189명이 탐색했습니다.

Why Are My Scoped CSS Custom Properties Ignored When Used in Outer Scope Calculations?

외부 범위에서 변수를 계산하는 데 사용될 때 CSS 범위가 지정된 사용자 정의 속성이 무시됨

구성 가능하고 느슨하게 결합된 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;
}

ol {
  font: 1em sans-serif;
}

.size-1 {
  font-size: var(--size-1);
}

.size-2 {
  font-size: var(--size-2);
}

.size-3 {
  font-size: var(--size-3);
}
로그인 후 복사

이 예에서 --size-* 속성은 --scale 사용자 정의 속성을 사용하여 루트 수준에서 계산됩니다. 그러나 .scale-* 클래스 내에서는 --scale 속성이 다시 정의됩니다. 이로 인해 루트 요소에서 상속된 --scale 값이 무시되고 --size-* 속성이 --scale의 기본값: 1을 사용하여 계산됩니다.

이 문제를 방지하려면, 적절한 수준에서 사용자 정의 속성을 정의하고 하위 요소에서 다시 정의하지 않는 것이 중요합니다. 이렇게 하면 범위가 지정된 사용자 정의 속성을 효과적으로 사용하여 외부 범위의 변수를 계산하고 구성 가능하고 느슨하게 결합된 CSS를 얻을 수 있습니다.

위 내용은 외부 범위 계산에 사용될 때 범위가 지정된 CSS 사용자 정의 속성이 무시되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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