>웹 프론트엔드 >HTML 튜토리얼 >오버플로 속성이 부동소수점을 지울 수 없는 이유를 분석합니다.

오버플로 속성이 부동소수점을 지울 수 없는 이유를 분석합니다.

WBOY
WBOY원래의
2024-01-27 09:31:06909검색

오버플로 속성이 부동소수점을 지울 수 없는 이유를 분석합니다.

float 속성을 지우는 데 오버플로 속성이 효과적이지 않은 이유에 대한 간략한 분석에는 특정 코드 예제가 필요합니다.

Floating 요소는 웹 페이지 레이아웃에서 다중 열 레이아웃 및 그림 부동과 같은 효과를 얻기 위해 자주 사용됩니다. 그러나 상위 컨테이너에서 부동 요소를 사용하는 경우 상위 컨테이너가 높이를 올바르게 계산하지 못해 레이아웃 혼란을 초래하는 경우가 많습니다. 이 문제를 해결하기 위해 우리는 일반적으로 부동 소수점을 지우는 몇 가지 기술을 사용합니다. 더 일반적인 방법은 오버플로 속성을 사용하는 것입니다.

overflow 속성은 CSS에서 일반적으로 사용되는 속성으로, 콘텐츠가 오버플로되는 방식을 제어하는 ​​데 사용됩니다. 여기에는 네 가지 선택적 값이 있습니다: visible(기본값, 콘텐츠가 잘리지 않고 상위 컨테이너를 오버플로함), hide(콘텐츠가 잘리고 오버플로 부분이 표시되지 않음), 스크롤(콘텐츠가 잘리고 상위 컨테이너에서 오버플로됨) 오버플로 부분은 스크롤 가능), 자동(필요에 따라 브라우저가 자동으로 스크롤 막대를 추가함)

일반적으로 상위 컨테이너의 하위 요소가 부동으로 설정되면 상위 컨테이너에 오버플로 속성을 추가하여 부동의 영향을 제거하려고 합니다. 예:

<style>
    .container {
        overflow: hidden;
    }
    .float-left {
        float: left;
        width: 50%;
    }
</style>

<div class="container">
    <div class="float-left">左侧内容</div>
    <div class="float-left">右侧内容</div>
</div>

그러나 이상하게도 이것이 작동하는 것 같습니다. 어떤 경우에는 작동하지 않을 수 있으며 상위 컨테이너는 여전히 높이를 올바르게 계산할 수 없습니다. 이 현상을 설명하기 위해서는 플로팅 요소의 상위 컨테이너 높이 계산 방법을 통해 이해해야 합니다.

상위 컨테이너는 자체 높이를 계산할 때 부동 하위 요소의 높이를 무시합니다. 부동 하위 요소가 상위 컨테이너보다 높더라도 상위 컨테이너는 하위 요소의 높이가 높이와 같다고 생각합니다. 떠 있기 전에. 이로 인해 컨테이너 높이가 내부 부동 요소에 올바르게 적용되지 않아 전체 레이아웃에 영향을 미칩니다.

플로트를 지우기 위해 오버플로 속성을 사용하려고 시도한 방법으로 돌아가서 실제로 오버플로 속성은 플로트 지우기에 직접적인 영향을 미치지 않습니다. 실제로는 상위 컨테이너에 대한 새로운 BFC(블록 수준 포맷팅 컨텍스트)를 생성합니다. BFC는 컨테이너 내부의 부동 요소로 외부 요소에 영향을 주지 않는 것으로 이해될 수 있습니다. BFC의 다양한 생성 방법과 다양한 브라우저 구현으로 인해 오버플로 속성이 유효하지 않을 수 있습니다.

그렇다면, 실제로 오버플로 속성을 통해 플로팅 효과를 지우고 싶다면 어떻게 해결해야 할까요? 다음은 참조할 수 있는 몇 가지 일반적인 솔루션입니다.

  1. clearfix 트릭 사용
    이는 플로팅 요소의 상위 컨테이너에 빈 블록 수준 요소를 추가하고 클리어 속성을 설정하여 플로트 효과를 지우는 일반적인 방법입니다. 예는 다음과 같습니다:
<style>
    .clearfix::after {
        content: "";
        display: block;
        clear: both;
        visibility: hidden;
        height: 0;
    }
    .float-left {
        float: left;
        width: 50%;
    }
</style>

<div class="clearfix">
    <div class="float-left">左侧内容</div>
    <div class="float-left">右侧内容</div>
</div>
  1. 부동산을 지우려면 ::after 의사 요소를 사용하세요
    이것은 더 간결한 해결책입니다. 부동 요소의 상위 컨테이너에서 ::after 의사 요소를 사용하고 Clearfix 스타일을 설정하세요.
<style>
    .container::after {
        content: "";
        display: table;
        clear: both;
    }
    .float-left {
        float: left;
        width: 50%;
    }
</style>

<div class="container">
    <div class="float-left">左侧内容</div>
    <div class="float-left">右侧内容</div>
</div>
  1. 플렉스박스 레이아웃 사용
    플렉스박스는 플로팅으로 인해 발생하는 문제를 더 잘 해결할 수 있는 새로운 레이아웃 방법입니다. 예는 다음과 같습니다:
<style>
    .container {
        display: flex;
    }
    .float-left {
        float: left;
        width: 50%;
    }
</style>

<div class="container">
    <div class="float-left">左侧内容</div>
    <div class="float-left">右侧内容</div>
</div>

요약하자면, 플로트 지우기에 대한 오버플로 속성의 영향은 직접적이지 않고 BFC를 생성하여 간접적으로 달성된다는 점에 유의해야 합니다. 동시에, 다양한 브라우저는 BFC를 다양한 방식으로 구현하므로 오버플로 속성이 유효하지 않게 될 수 있습니다. 따라서 오버플로 속성 외에도 Clearfix 기술, ::after 의사 요소를 사용하여 부동 소수점을 지우거나 Flexbox 레이아웃과 같은 방법을 사용하여 부동 소수점을 지우는 등의 다른 솔루션을 시도할 수도 있습니다.

위 내용은 오버플로 속성이 부동소수점을 지울 수 없는 이유를 분석합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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