>웹 프론트엔드 >CSS 튜토리얼 >플로팅 요소가 포함된 Div를 오버플로하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

플로팅 요소가 포함된 Div를 오버플로하는 이유는 무엇이며 어떻게 해결할 수 있습니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-27 18:37:12394검색

Why Do Floated Elements Overflow Their Containing Div, and How Can I Fix It?

부동 요소 이스케이프 포함: Div 오버플로 문제 해결

div 내에서 부동 요소로 작업할 때 부동 요소가 div 이상으로 확장되는 문제가 발생할 수 있습니다. 포함된 div의 경계. 이러한 크기 차이로 인해 의도한 레이아웃이 중단될 수 있습니다.

근본 원인:

플로트가 일반 문서 흐름에서 제거되어 상위 요소에 간격이 생깁니다. 결과적으로 플로팅이 아닌 콘텐츠가 이 빈 공간을 채우기 위해 조정되어 플로팅 요소를 포함하지 못하는 더 작은 div가 생성됩니다.

해결책 1: 오버플로 제어

  • 오버플로 추가: 상위 div에 숨겨진:
#parent { overflow: hidden }

이렇게 하면 오버플로가 방지됩니다. 부동 요소를 포함하고 div의 경계 내에 유지되도록 합니다. 그러나 div의 높이를 넘어서 확장되는 콘텐츠는 잘릴 수 있습니다.

해결책 2: 상위 Div 플로팅

  • 상위 div 플로팅:
#parent { float: left; width: 100% }

이렇게 하면 상위 div가 플로팅 콘텐츠를 수용하기 위해 수직으로 늘어날 수 있습니다. 무한한 확장을 방지하려면 div의 너비가 고정된 값이나 백분율로 설정되어 있는지 확인하세요.

해결책 3: 요소 지우기

  • 아래에 명확한 요소를 사용하세요. 플로팅 콘텐츠:
<div class="parent">
  <img class="floated_child" src="..." />
  <span class="clear"></span>
</div>
span.clear { clear: left; display: block; }

클리어 요소는 Sentinel은 다음 콘텐츠가 플로팅 콘텐츠 아래의 새 줄에서 시작되도록 강제하여 div의 올바른 크기를 복원합니다.

위 내용은 플로팅 요소가 포함된 Div를 오버플로하는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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