>웹 프론트엔드 >CSS 튜토리얼 >CSS 특이성에서 `.foo a`가 `a:hover` 및 `a:active`를 재정의하는 이유는 무엇입니까?

CSS 특이성에서 `.foo a`가 `a:hover` 및 `a:active`를 재정의하는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-11-26 16:27:14341검색

Why Does `.foo a` Override `a:hover` and `a:active` in CSS Specificity?

특정성 수수께끼: .foo a 선택기가 a:hover, a:active

CSS 특이성은 선택기에 따라 스타일이 적용되는 방식을 결정합니다. 무게. 주어진 문제에서 .foo a 선택기는 a:hover 및 a:active와 충돌합니다.

특정성 이해

특정성은 태그, 클래스 수에 따라 결정됩니다. , 선택기의 ID. 각 수준은 특정 가중치를 갖습니다. 이 경우 제공된 특이성 표를 보면 .foo a:link 및 .foo a:visited가 a:hover 및 a:active(0 0 1 1)보다 특이도(0 0 2 1)가 더 높다는 것을 알 수 있습니다.

.foo a가 재정의되는 이유

.foo a 선택기가 더 구체적입니다. a:hover 및 a:active보다 foo 클래스가 있는 요소 내의 링크에 적용되기 때문입니다. 요소가 동일한 특이성을 가진 여러 선택기를 만나면 마지막으로 선언된 스타일이 적용됩니다.

.foo 선택기 수정

a:hover 및 a:를 허용하려면 활성 스타일이 우선순위를 가지려면 .foo a 선택기가 더 낮은 특정성을 갖도록 수정되어야 합니다. 한 가지 가능한 수정 사항은 다음과 같습니다.

.foo a:hover, .foo a:active {
    color: red;
}

hover 및 활성 의사 클래스 앞에 .foo를 추가하면 특정성이 a:hover 및 a:active보다 높게 유지되어 해당 의사 클래스의 스타일이 다음과 같이 유지됩니다. foo가 있는 요소 내에 적용됨 class.

요점

특수성은 CSS 스타일이 적용되는 방식을 결정합니다. 스타일 우선순위를 제어하고 원하는 시각적 효과를 얻으려면 이 개념을 이해하는 것이 중요합니다.

위 내용은 CSS 특이성에서 `.foo a`가 `a:hover` 및 `a:active`를 재정의하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.