>웹 프론트엔드 >CSS 튜토리얼 >플로트 정의 및 플로트 클리어런스(BFC)

플로트 정의 및 플로트 클리어런스(BFC)

零下一度
零下一度원래의
2017-05-10 11:57:301683검색

Float

1. float이란

Float는 해당 요소의 <a href="http://www.php.cn/wiki/919.html" target="_blank">float</a> 속성 none이 아닐 때 발생합니다.

<p class="float">float</p>
.float {
  float: left;
  width: 100px;
  height: 100px;
  background-color: #ddd;
}

2. 플로팅의 영향

  1. 플로팅으로 인해 요소가 문서 흐름에서 벗어나게 됩니다.

  • 부모 요소는 크게 축소되어 있습니다. 즉, 부동 요소를 포함하지 않습니다.
    예를 들어 위 코드는

    플로트 정의 및 플로트 클리어런스(BFC)

    상위 요소가 크게 접혀 있습니다.

  • 텍스트 줄 바꿈으로 표시됩니다. .

    플로트 정의 및 플로트 클리어런스(BFC)

    텍스트 줄바꿈 효과


    .normal 요소의 너비가 .float 요소를 덮는 것을 확인할 수 있습니다. 그러나 .float 요소 아래에는 텍스트가 없습니다. 이는 텍스트가 "압축"되어 있음을 의미합니다. 이는 문서 흐름에서 벗어나더라도 텍스트 흐름에서는 벗어나지 않기 때문입니다. 이 효과는 float 속성의 원래 의도이기도 합니다. 코드는 다음과 같습니다.

    
      <p class="float">float</p>
      

    正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素正常元素

    body {
      background-color: #ccc;
    }
    .float {
      float: left;
      width: 100px;
      height: 100px;
      background-color: #ddd;
    }
    .normal {
      background-color: #fff;
    }
  • 플로팅 요소의 여백은 병합되지 않습니다.
    여백 병합 관련 내용을 보려면 여기를 클릭하세요.

  • 요소가 부동되면 인라인 블록 요소, 즉 <a href="http://www.php.cn/wiki/927%EC%9D%B4%20%EB%90%A9%EB%8B%88%EB%8B%A4.%20.html" target="_blank">디스플레이<code><a href="http://www.php.cn/wiki/927.html" target="_blank">display</a>: inline-block: 인라인 블록.

  • 3. 플로팅 애플리케이션

    • 위에서 언급한 텍스트 래핑.

    • 왼쪽과 오른쪽의 너비가 고정되고 가운데가 적응형인 3열 레이아웃을 작성합니다.

      <body>
        <p class="left float">left</p>
        <p class="right float">right</p>
        <p class="mid">自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素</p>
      </body>
      rrree

      여기서 의도적으로 margin 값을 추가했는데 효과를 볼 수 있습니다.

      플로트 정의 및 플로트 클리어런스(BFC)

      3열 레이아웃

      body.midmargin과 함께 떨어집니다. 이는 앞서 소개한 마진 병합으로 설명할 수 있습니다.

      ps: 처음 이 3열 레이아웃을 작성할 때 html은 이렇게 작성했습니다.

      body {
        background-color: #ccc;
      }
      .float {
        float: left;
        width: 100px;
        height: 100px;
        background-color: #ddd;
      }
      .left {
        float: left;
      }
      .right {
        float: right;
      }
      .mid {
        height: 100px;
        background-color: #fff;
        margin: 200px; /*故意加上了上下 margin 值*/
      }

      위와 같이 가운데 적응 요소를 가운데에 작성하는 것이 사실 더 논리적입니다. 하지만 이렇게 작성하면 .mid 요소가 블록 수준 요소이므로 오른쪽 요소가 아래로 떨어지며 .left는 아래로 떨어지지 않습니다. 원래는 문서 흐름 요소와 분리된 부동 소수점입니다.

    Clear float

    Clear on child elements

    여기서는 의미 없는 태그를 생성하지 않는 메서드만 작성합니다.

    • 플로팅 요소 뒤에 형제 요소가 있는 경우 해당 형제 요소에 clear 속성을 ​​추가할 수 있습니다.
      텍스트가 해당 코드 부분을 둘러싸는 경우 .normalclear:left 또는 clear:both를 추가하세요. 여기서는 clear의 구체적인 사용법을 자세히 설명하지 않습니다.

    • 플로팅을 제거하려는 요소에 의사 클래스 또는 의사 요소를 추가합니다.

      <body>
        <p class="left float">left</p>
        <p class="mid">自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素自适应宽度元素</p>
        <p class="right float">right</p>
      </body>

      :after 사용에 대한 정보는 MDN 문서를 참조하세요.

    은 상위 요소, 즉 BFC에서 지워집니다.

    BFC(Block Formatting Context), 즉 블록 수준 서식 컨텍스트에 대한 공식적인 설명은 다음과 같습니다.

    부동, 절대 위치 요소(positionabsolute 또는 fixed), 인라인 블록 요소 display:inline-block, 테이블 셀 display:table-cell, 테이블 제목 display:table-captionoverflow 속성 값이 visible 요소(값이 뷰포트 viewport에 전파되는 경우 제외)는 새로운 블록 수준 서식 지정 컨텍스트를 생성합니다.

    요약하면 다음 조건 중 하나를 충족해야 합니다.

    1. float 아님 none

    2. positionstatic이 아니거나 relative

    3. displaytable-cell, table-caption, inline-block, flex, inline-flex

    4. 아님 overflowvisible

    위의 속성 중 하나를 상위 요소에 추가하여 조건을 충족하는 한, 즉, 상위 요소에 추가하십시오. 하위 요소의 부동을 지우려면 BFC로 이동하십시오.

    【관련 추천】

    1.

    무료 CSS 온라인 동영상 튜토리얼

    CSS 온라인 매뉴얼

    3.

    php.cn Dugu Jiujian (2) - CSS 비디오 튜토리얼

    위 내용은 플로트 정의 및 플로트 클리어런스(BFC)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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