>  기사  >  웹 프론트엔드  >  내 중첩된 Div 여백이 겹치는 이유는 무엇입니까?

내 중첩된 Div 여백이 겹치는 이유는 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-10-26 13:11:03982검색

Why are My Nested Div Margins Overlapping?

중첩 Divs의 여백 겹침 문제 해결

겹침 문제 조사

제시된 코드 조각에는 다음과 같은 내용이 있는 것으로 보입니다. 중첩된 div의 여백이 겹쳐 예상치 못한 간격이 발생하는 문제입니다. 원인을 이해하기 위해 HTML과 CSS를 살펴보겠습니다.

HTML 구조

HTML 구조에는 세 개의 하위 div가 포함된 "alignright" 클래스가 있는 상위 div가 포함됩니다. '소셜', '연락처', '검색'입니다. 이러한 하위 div에 적용된 여백으로 인해 중복이 발생합니다.

CSS 선언

여백을 관리하는 CSS 선언은 다음과 같습니다.

<code class="css">#header .social {margin-top: 50px;}
#header .contact {margin: 20px 70px 20px 0; font-size: 14px; font-weight: bold;}
#header .search {margin: 10px 0 0;}</code>

범인 규명: 마진 축소

마진이 겹치는 현상은 "마진 붕괴" 현상으로 인해 발생합니다. 수직으로 인접한 두 여백이 인라인 또는 블록 수준 요소에 속하는 경우 더 큰 여백은 축소되고 더 작은 여백은 무시됩니다. 이 경우 "연락처" 및 "검색" div의 여백을 축소하는 것은 "소셜" div(50px)의 더 큰 여백입니다.

문제 해결

여백 축소를 방지하기 위해 고려할 수 있는 몇 가지 접근 방식이 있습니다.

  1. 간격 사용: 도입할 요소 사이에
    태그 또는 CSS Clearfix 기술을 추가합니다. 여백 붕괴를 방지합니다.
  2. 부동 또는 절대 위치 지정 사용: 부동 또는 절대 위치 지정을 사용하여 일반 흐름에서 요소를 제거합니다. 이렇게 하면 여백이 다른 요소와 함께 축소되지 않습니다.

대체 옵션

특정 상황에서는 특정 간격을 얻기 위해 의도적으로 여백을 축소할 수 있습니다. 효과. 추가 공간을 만들려면 음수 여백을 사용하는 것이 좋습니다. 하지만 마이너스 마진을 사용할 경우 예측할 수 없는 결과가 발생할 수 있으므로 주의하세요.

위 내용은 내 중첩된 Div 여백이 겹치는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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