찾다

CSS의 부동 속성

Feb 25, 2017 pm 02:39 PM

1. Float의 특징

1. 이미지 주위에 텍스트 적용

2. 🎜>

3. 다중 열 플로팅 레이아웃

4. 플로팅 요소의 너비와 높이는 가변적이지만 해당 값은 설정할 수 있습니다.

2. 코어로 해결되는 문제

이미지를 텍스트로 둘러쌉니다. img 태그인 경우 여러 텍스트 태그가 컨테이너에 배치됩니다. floats 이면 텍스트 라벨이 이미지를 둘러쌉니다.

<img src="/static/imghwm/default1.png"  data-src="../img/a.jpg"  class="lazy"     style="max-width:90%" alt="">
        <p>001文件内容文件内容文内容文件内容<br/>
        文件内容文件内容文件内容文件内容文件内内容文件内容<br/>
        文件内容文件内容文件内容文件内容文件内容<br/> 
        文件内容文件内容文件内容文件内容文内容文件内容文件内容<br/>
        <p>p标签文件内容文件内容文件内容文件内容文件内容文容文件内容文件内容文件内容</p>
        <p>p标签文件内容文件内容文件内容文件内容文件内容文件内容</p>
        文件内容文件内容文件内容文件件内容文件内容文件内容<br/>
        文件内容文件内容文件内容文件内容文件内容文件内容文件内容文件内容<br/> 
        文件内容文件内容文件内容文件内容文件内容文件内内容文件内容<br/>
        文件内容文件内容文件内容文件容文件内容文件内容<br/>
        文件内容文件内容文件内容文件容文件内容文件内容<br/>
        </p>

CSS의 부동 속성

2.1 이것은 질문입니다

플로팅 요소 vs 일반 요소 인접하고, 플로팅 요소와 일반 요소 사이에 명확한 플로트가 없습니다. 이때 일반 요소는 플로팅 요소로 덮히지만 포함된 콘텐츠는 플로팅 요소 주위에 표시됩니다.

<p style="width: 100px; height: 200px; background: red;float: left;" >001</p> 
<p style="width: 100px; height: 200px; background: gray;float: none;" ><p>002</p></p>

001은 부동, 002는 부동하지 않지만 002 요소 자체는 001로 덮여 있지만 내용은 001 부근에 표시됩니다.

CSS의 부동 속성

3. 비핵심 및 주요 응용 분야

열 레이아웃: 블록을 가로로 배치 먼저 정렬한 다음 초과된 부분으로 새 줄을 시작합니다.

주요 기능

1. 부모 키 붕괴(이것도 심각한 문제입니다)

.wrap{
           background:red; 
           padding:10px;
           width:auto;
        }
        .left{
            background:gray;
            width:200px;
            height:100px;
            float:left;
        }
        .right{
            background:yellow;
            width:100px;
            height:100px;
            float:left;
        }

<p class="wrap">
        <p class="left">left</p>
        <p class="right">right</p>
</p>

CSS의 부동 속성

2. 너비와 높이는 가변 하위 요소가 되지만 너비와 높이 설정은 유효합니다

.wrap{
           background:red; 
           padding:10px;
           float:left;
        } 
        .left{
            width:100px;
            background:gray;
        }
        .right:{
            width:200px;
            background:yellow;
        }

아아아아

CSS의 부동 속성

2.고도 붕괴 문제를 해결

먼저 BFC와 IFC의 두 가지 기본 개념은 브라우저 렌더링과 밀접하게 관련되어 있으므로 이해해야 합니다.

1.BFC(블록 수준 서식 컨텍스트)

독립적으로 렌더링되는 영역으로, 영역이 내부적으로 어떻게 배치되는지 규정하며, 외부와는 아무런 관련이 없습니다.

1.1 내부 상자는 세로로 하나씩 배치됩니다.

1.2 상자의 세로 거리는 여백에 의해 결정되며, 상자에 속하는 인접한 두 상자의 여백은 다음과 같습니다. 동일한 BFC가 겹칩니다

1.3 BFC 영역은 float와 겹치지 않습니다

<p class="wrap">
        <p class="left">left</p>
        <p class="right">right</p>
</p>

.head{
            background:pink;
            margin: 20px 0px;
            height:100px;
        }
        .wrap{
           background:red; 
           padding:10px;
           margin:20px 0px;
           overflow:hidden;
        } 
        .left{
            width:100px;
            background:gray; 
            margin:10px 0px;
        }
        .right:{
            width:200px;
            background:yellow;  
            margin:20px 0px;
        }

CSS의 부동 속성

두 상자 .head와 .wrap 사이에는 위쪽과 아래쪽에 20px 여백이 있지만 .head와 .left 사이에는 겹칩니다. .head에는 20px 여백이 있습니다. .wrap이 BFC(overflow:hidden)를 생성하기 때문에 10px 여백과 겹침이 발생하지 않습니다.

1.4 각 상자의 왼쪽 여백은 테두리 상자의 왼쪽(오른쪽과 동일)과 접촉하며 플로트도 마찬가지입니다

2. 행 수준 서식 지정 컨텍스트)

상자는 포함 블록의 상단부터 시작하여 수평으로 하나씩 배치됩니다. 가로 여백, 테두리, 패딩이 차지하는 공간을 모두 합친 것입니다(디스플레이는 인라인, 인라인 블록이며 인라인 특성을 갖는 요소는 다음과 같은 특징을 가집니다). 규칙은 다음과 같습니다.

2.1 너비와 높이를 지정할 수 없습니다

2.2 세로 방향에서는 Margin, Padding, Border를 사용할 수 없습니다

2.3 왼쪽 라인 상자는 포함 블록의 왼쪽에 가깝고 라인 상자의 오른쪽은 포함 상자의 오른쪽과 같은 높이이며, 포함 블록의 가장자리와 라인 사이에 부동 소수점을 삽입할 수 있습니다. 상자.

2.4 인라인 상자의 높이는 line-height에 따라 결정됩니다.

이 섹션의 예는 디스플레이 장의 인라인 요소를 참조하세요.

3. 솔루션

은 BFC의 원리를 기반으로 주로 구현되는데, 이는 BFC가 전체 영역을 렌더링하고 너비와 높이도 계산하기 때문입니다. 이것은 또한 float를 지우는 전설적인 솔루션입니다

3.1 상위 컨테이너에 BFC를 생성하는 방법

3.1.1 BFC를 생성하는 방법

a) Float 값 이외의 없음

b) 표시 이외의 오버플로 값

c) 표시 값은 table-cell, table-caption, inline-block, flex, inline-flex 등입니다. .

d) 위치 값은 절대, 고정

e) 필드 세트 요소

3.1.2 부동 소수점 지우기

a) 부동, 오버플로 및 표시 가능 세 가지 방법으로 지워질 수 있습니다. 그러나 position과 fieldset이 bfc를 생성하더라도 float를 지울 수는 없습니다(즉, 높이 붕괴 문제를 해결할 수 없습니다). 주된 이유는 position과 fieldset 모두 상위 컨테이너의 높이를 확장하기 위해 하위 요소가 필요하지만 하위 요소가 부동된 후에는 높이가 없으므로 실패하기 때문입니다.

b) 부동, 오버플로, 표시 샘플 코드:

<p class="head">head</p>
    <p class="wrap">
        <p class="left">left</p>
        <p class="right">right</p>
    </p>

<p class="wrap" >
        <p class="left">left</p>
        <p class="right">right</p>
    </p>
<p class="footer">footer</p>

CSS의 부동 속성

3.1.3 最后一个子元素clear:both

利用clear:both触发父容器重新计算高度的原理实现,示例代码如下:

.wrap{
            background: gray;
            padding: 10px; 
        }
        .left, .right{
            background: red;
            float: left;
            width: 200px;
            height: 100px;
        }
        .right{
            background: yellow;
        }
        .footer{
            background: pink;
        }
        .clear{
            clear: both;
            zoom: 1;
        }

<p class="wrap" >
        <p class="left">left</p>
        <p class="right">right</p>
        <p class="clear"></p>
    </p>
<p class="footer">footer</p>

3.1.4 After添加最后一个子元素

利用css的:after伪元素实现,动态插入元素并清除浮动:

.wrap{
            background: gray;
            padding: 10px; 
        }
        .wrap:after{
            content: &#39;&#39;;
            display: block;
            overflow: hidden;
            clear: both;
        }
        .left, .right{
            background: red;
            float: left;
            width: 200px;
            height: 100px;
        }
        .right{
            background: yellow;
        }
        .footer{
            background: pink;
        }

<p class="wrap" >
        <p class="left">left</p>
        <p class="right">right</p> 
    </p>
<p class="footer">footer</p>

4. 总结

1. 利用bfc方式清除浮动,简单、浏览器支持良好,但在IE6-版本支持存在问题。但是存在以下局限性,要适环境而用:

    a) Overflow方式:滚动条会被隐藏,如果子内容超高则存在显示不全的问题;

    b) Float方式:让父容器浮动,那么就存在对父容器同辈元素的影响;

    c) Dipslay方式:让父容器变为table或者flex等,都存在不明确的影响,大家都不推荐使用。

2. 最佳解决方案:利用:after添加一个伪元素并给予clear:both和zoom:1来实现清除浮动,兼容性好,对环境影响最小。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持PHP中文网。

更多CSS의 부동 속성相关文章请关注PHP中文网!

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

Goofonts는 개발자 부인과 디자이너 남편이 서명 한 사이드 프로젝트로, 둘 다 타이포그래피의 큰 팬입니다. 우리는 Google에 태그를 지정했습니다

시대를 초월한 웹 개발 기사시대를 초월한 웹 개발 기사Apr 12, 2025 am 11:44 AM

Pavithra Kodmad

섹션 요소와의 거래섹션 요소와의 거래Apr 12, 2025 am 11:39 AM

두 기사가 정확히 같은 날에 출판되었습니다.

JavaScript API 상태로 GraphQL 쿼리를 연습하십시오JavaScript API 상태로 GraphQL 쿼리를 연습하십시오Apr 12, 2025 am 11:33 AM

GraphQL API를 구축하는 방법을 배우는 것은 매우 어려울 수 있습니다. 그러나 10 분 안에 GraphQL API를 사용하는 방법을 배울 수 있습니다! 그리고 그것은 완벽하게 얻었습니다

구성 요소 수준 CMS구성 요소 수준 CMSApr 12, 2025 am 11:09 AM

구성 요소가 데이터를 쿼리하는 환경에 거주하면 근처에 사는 경우 시각적 구성 요소와

오프셋 경로로 원에 유형을 설정하십시오오프셋 경로로 원에 유형을 설정하십시오Apr 12, 2025 am 11:00 AM

여기 Yuanchuan의 합법적 인 CSS 속임수입니다. 이 CSS 속성 오프셋 경로가 있습니다. 옛날 옛적에, 그것은 모션 경로라고 불렸다가 이름이 바뀌 었습니다. 나

CSS에서 '리버 트'는 무엇을합니까?CSS에서 '리버 트'는 무엇을합니까?Apr 12, 2025 am 10:59 AM

Miriam Suzanne 은이 주제에 대한 Mozilla 개발자 비디오에서 설명합니다.

현대 애호가현대 애호가Apr 12, 2025 am 10:58 AM

나는 이런 것들을 좋아한다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음