범위가 지정된 CSS 사용자 정의 속성이 상속된 값을 재정의하지 못하는 이유는 무엇입니까?
범위가 지정된 CSS 사용자 정의 속성: 상속된 값 재정의
CSS 사용자 정의 속성으로 작업할 때 정의된 범위는 해당 동작에 영향을 미칩니다. 이 경우 범위가 지정된 사용자 정의 속성은 외부 범위에 정의된 변수를 기반으로 크기를 조정하는 데 사용됩니다. 그러나 세 목록이 모두 동일한 규모로 나타나기 때문에 원하는 효과를 얻을 수 없습니다.
범위 지정 문제 이해
-로 정의된 사용자 정의 속성 다른 규칙 내에 중첩된 규칙은 전역 범위로 간주되며 문서 내의 모든 요소에 영향을 미칩니다. 그러나 사용자 정의 속성이 중첩된 규칙 내에 정의되면 해당 규칙과 해당 하위 항목으로 범위가 지정됩니다. 즉, 해당 규칙 외부의 모든 요소는 사용자 정의 속성 값을 상속하지 않습니다.
사용자 정의 속성 재설정
제공된 코드에서 루트 요소는 - -scale 사용자 정의 속성을 기반으로 --size-* 값을 계산합니다. 이후 하위 요소는 자체 --scale 사용자 정의 속성을 정의합니다. 이로 인해 하위 요소가 루트 요소에서 상속된 --scale 값을 재정의하게 됩니다.
이 문제를 해결하려면 하위 요소 내의 --scale 사용자 정의 속성을 새 값으로 재설정해야 합니다. 계산에 사용됩니다. 이렇게 하면 사용자 정의 속성의 범위가 효과적으로 하위 요소와 해당 하위 요소로 지정됩니다.
업데이트된 코드
수정 사항이 포함된 업데이트된 코드 버전은 다음과 같습니다.
: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); } .size-1 { font-size: var(--size-1) } .size-2 { font-size: var(--size-2) } .size-3 { font-size: var(--size-3) } .scale-1x { --scale: 1 } .scale-2x { --scale: 2 } .scale-3x { --scale: 3 } html { font: 1em sans-serif; background: papayawhip; } ol { float: left; list-style: none; margin: 1rem; }
위 내용은 범위가 지정된 CSS 사용자 정의 속성이 상속된 값을 재정의하지 못하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

다른 날, 나는 Corey Ginnivan의 웹 사이트에서 스크롤 할 때 카드 모음이 서로 쌓이는 것을 발견했습니다.

Google Fonts가 새로운 디자인 (트윗)을 출시 한 것을 볼 수 있습니다. 마지막 큰 재 설계와 비교할 때 이것은 훨씬 더 반복적 인 느낌이 듭니다. 차이를 간신히 말할 수 있습니다

프로젝트에 카운트 다운 타이머가 필요한 적이 있습니까? 그런 것은 플러그인에 도달하는 것이 당연하지만 실제로는 훨씬 더 많습니다.

플렉스 레이아웃의 보라색 슬래시 영역에 대한 질문 플렉스 레이아웃을 사용할 때 개발자 도구 (d ...)와 같은 혼란스러운 현상이 발생할 수 있습니다.

요소 수가 고정되지 않은 경우 CSS를 통해 지정된 클래스 이름의 첫 번째 자식 요소를 선택하는 방법. HTML 구조를 처리 할 때 종종 다른 요소를 만듭니다 ...

새로운 프로젝트가 시작될 때, Sass 컴파일은 눈을 깜박이게합니다. 특히 BrowserSync와 짝을 이루는 경우 기분이 좋습니다.

프론트 엔드 개발에서 Windows와 같은 구현 방법 ...
