>웹 프론트엔드 >프런트엔드 Q&A >CSS 스타일은 상속되지 않습니다

CSS 스타일은 상속되지 않습니다

PHPz
PHPz원래의
2023-05-14 21:26:391215검색

CSS는 웹 디자인에서 매우 중요한 도구입니다. 웹 페이지를 아름답게 만드는 다양한 스타일을 제공하여 사용자의 웹 사이트 경험을 향상시킵니다. 그러나 때때로 CSS에서는 더 어려운 문제에 직면합니다. 문제 중 하나는 CSS 스타일이 상속되지 않는다는 것입니다.

상속되지 않는 CSS 스타일은 무엇인가요?

간단히 말하면 선택기 아래에 스타일을 설정할 때 CSS 스타일은 상속되지 않지만 이 스타일은 선택기의 하위 요소로 상속되지 않습니다. 이러한 상황은 종종 웹 디자인을 극도로 어렵게 만듭니다. 예를 들어, 전체 웹사이트 본문 텍스트의 글꼴 크기를 설정하려고 하지만 선택기 아래 하위 요소의 글꼴 크기가 이미 설정되어 있는 경우 선택기 아래 모든 하위 요소는 글꼴 크기를 상속하지 않습니다. .글꼴 크기. 이를 위해서는 각 하위 요소의 글꼴 크기를 재설정해야 하는데 이는 매우 번거롭고 코드 유지 관리에 도움이 되지 않습니다.

CSS 스타일이 상속되지 않는 이유

일반적으로 다음과 같은 이유로 CSS 스타일이 상속되지 않습니다.

  1. 특수 CSS 속성 사용

일부 CSS 속성은 상속을 지원하지 않습니다. 예를 들어, 디스플레이, 위치, 부동 및 지우기와 같은 CSS 속성은 상속을 지원하지 않습니다. 이러한 속성이 선택기에서 사용되는 경우 선택기 아래의 모든 하위 요소는 스타일을 상속하지 않습니다.

  1. 하위 요소는 상위 요소의 스타일을 상속하지만 변경됩니다.

때때로 하위 요소에 새 스타일을 설정하면 해당 스타일이 더 이상 상위 요소에서 상속되지 않습니다. 이는 일반적으로 새 스타일이 상속된 스타일과 충돌하여 상속된 스타일이 재정의되기 때문입니다.

  1. 하위 요소는 선택기 규칙을 통해 형제 요소로 해석됩니다.

하위 요소의 선택기 규칙이 상위 요소의 하위 요소가 아닌 형제 요소로 해석되면 스타일이 상속되지 않습니다. 예를 들어 + 또는 ~를 사용하여 스타일 시트에서 형제 요소를 선택하면 해당 스타일은 상속되지 않습니다.

CSS 스타일이 상속되지 않는 문제를 해결하는 방법

  1. 전역 선택기 사용

전역 선택기를 사용하면 하위 요소가 상위 요소의 스타일을 상속받게 될 수 있습니다. 아래와 같이:

상위 요소 스타일:

.parent-element {
  font-size: 16px;
}

하위 요소 스타일:

.child-element {
  all: initial;
  font-size: inherit;
}

하위 요소 스타일에서는 all: 초기화를 사용하여 모든 스타일을 기본값으로 재설정한 다음 글꼴 크기: 상속을 사용하여 상속합니다. 상위 요소의 글꼴 크기.

  1. 더 나은 상속을 위해 CSS 속성 사용

일부 CSS 속성은 상속을 지원합니다. 상위 요소에 의해 한 번 설정될 수 있지만 하위 요소는 자동으로 이 값을 상속합니다. 예를 들어 색상, 글꼴 크기, 글꼴 계열 등의 CSS 속성은 모두 상속을 지원합니다. 선택기에서 이러한 속성을 사용하면 하위 요소가 이 속성을 상속할 수 있습니다.

  1. 선택기 중첩 줄이기

선택기 중첩을 피하면 하위 요소 상속 문제를 피할 수 있습니다. CSS 스타일을 작성할 때 간단한 선택기를 사용하고 선택기 중첩을 피해야 합니다.

  1. 스타일이 충돌할 때 !important 추가

어떤 경우에는 특수 CSS 속성을 사용하거나 선택기 중첩을 피할 수 없습니다. 이 경우 스타일의 우선순위를 보장하기 위해 스타일 끝에 !important를 사용할 수 있습니다. 가장 높으므로 다른 스타일보다 우선합니다.

요약

CSS에서 상속되지 않은 스타일은 웹 디자인을 특히 번거롭게 만들 수 있습니다. 그러나 몇 가지 기술과 방법을 익히면 이 문제를 쉽게 해결할 수 있습니다. 전역 선택기 사용, 더 나은 상속 기능을 갖춘 CSS 속성 사용, 선택기 중첩 감소 및 !important 사용은 CSS 스타일의 비상속 문제를 처리하는 일반적인 방법입니다.

위 내용은 CSS 스타일은 상속되지 않습니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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