외부 범위에서 변수를 계산하는 데 사용될 때 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!