Vertiefendes Verständnis und Anwendung von Float-Eigenschaften

高洛峰
Freigeben: 2016-10-31 11:19:35
Original
1719 Leute haben es durchsucht

1. Funktionen von Float

2. Erstellen Sie ein mehrspaltiges Floating-Layout

4. Die Breite und Höhe schwebender Elemente sind adaptiv, ihre Werte können jedoch festgelegt werden.

2. Kern gelöste Probleme

Text umgibt das Bild: Das img-Tag und mehrere Textbeschriftungen werden in einem Container platziert. Wenn das img schwebt, werden die Textbeschriftungen das Bild umgeben.

<img src="../img/a.jpg"   style="max-width:90%" alt="">
        <p>001文件内容文件内容文内容文件内容<br/>
        文件内容文件内容文件内容文件内容文件内内容文件内容<br/>
        文件内容文件内容文件内容文件内容文件内容<br/> 
        文件内容文件内容文件内容文件内容文内容文件内容文件内容<br/>
        <p>p标签文件内容文件内容文件内容文件内容文件内容文容文件内容文件内容文件内容</p>
        <div>Div标签文件内容文件内容文件内容文件内容文件内容文件内容</div>
        文件内容文件内容文件内容文件件内容文件内容文件内容<br/>
        文件内容文件内容文件内容文件内容文件内容文件内容文件内容文件内容<br/> 
        文件内容文件内容文件内容文件内容文件内容文件内内容文件内容<br/>
        文件内容文件内容文件内容文件容文件内容文件内容<br/>
        文件内容文件内容文件内容文件容文件内容文件内容<br/>
        </p>
Nach dem Login kopieren

2.1 Dies ist ein ProblemVertiefendes Verständnis und Anwendung von Float-Eigenschaften

Das schwebende Element grenzt an das normale Element an und es gibt keine klare Schwimmzone zwischen dem schwebenden Element und Das normale Element wird vom schwebenden Element abgedeckt, der enthaltene Inhalt wird jedoch um das schwebende Element herum angezeigt.

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

001 schwimmt, 002 schwimmt nicht, aber das 002-Element selbst wird von 001 abgedeckt, aber der Inhalt wird um 001 herum angezeigt. Vertiefendes Verständnis und Anwendung von Float-Eigenschaften

3. Nicht-Kern- und Hauptanwendungsfelder

Spaltenlayout: Lassen Sie die Blöcke zuerst horizontal anordnen und beginnen Sie dann eine neue Reihe für die überschüssigen Teile.

Hauptmerkmale

1. Zusammenbruch der Elterngröße (dies ist ebenfalls ein ernstes Problem)

.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;
        }
Nach dem Login kopieren
<div class="wrap">
        <div class="left">left</div>
        <div class="right">right</div></div>
Nach dem Login kopieren
Nach dem Login kopieren

2 . Die Breite und Höhe werden zu adaptiven Unterelementen, aber die Einstellungen für Breite und Höhe sind gültig Vertiefendes Verständnis und Anwendung von Float-Eigenschaften

.wrap{
           background:red; 
           padding:10px;
           float:left;
        } 
        .left{
            width:100px;
            background:gray;
        }
        .right:{
            width:200px;
            background:yellow;
        }
Nach dem Login kopieren
<div class="wrap">
        <div class="left">left</div>
        <div class="right">right</div></div>
Nach dem Login kopieren
Nach dem Login kopieren

2. Lösen Sie das Problem des HöhenkollapsesVertiefendes Verständnis und Anwendung von Float-Eigenschaften

Zunächst müssen wir die beiden Grundkonzepte BFC und IFC verstehen, da sie eng mit dem Browser-Rendering verbunden sind.

1.BFC (Formatierungskontext auf Blockebene)

Es handelt sich um einen unabhängig gerenderten Bereich, der festlegt, wie der Bereich intern angeordnet ist und nichts mit der Außenseite zu tun hat sind wie folgt:

1.1 Die internen Boxen werden vertikal nacheinander platziert

1.2 Der vertikale Abstand der Box wird durch den Rand und die Ränder zweier benachbarter Boxen bestimmt, die dazu gehören Derselbe BFC überlappt sich

1.3 Der BFC-Bereich überlappt nicht mit Float

.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;
        }
Nach dem Login kopieren
<div class="head">head</div>
    <div class="wrap">
        <div class="left">left</div>
        <div class="right">right</div>
    </div>
Nach dem Login kopieren

Zwischen der Ober- und Unterseite befindet sich ein 20-Pixel-Rand Es kam jedoch zu einer Überlappung zwischen Vertiefendes Verständnis und Anwendung von Float-Eigenschaften

.head und .left, .head hat einen 20-Pixel-Rand und .left hat einen 10-Pixel-Rand, da .wrap einen BFC(-Überlauf) erzeugt :versteckt).

1.4 Der linke Rand jedes Felds berührt die linke Seite des Randfelds (das Gleiche gilt für Floats

2. Formatierungskontext auf Zeilenebene)

Boxen werden horizontal nacheinander platziert, beginnend am oberen Rand des enthaltenden Blocks. Der von den horizontalen Rändern, Rändern und Polstern eingenommene Platz wird zusammengefügt (Anzeige erfolgt inline, Inline-Block; Elemente mit Inline-Eigenschaften haben die folgenden Eigenschaften). Die Regeln lauten wie folgt:

2.1 Breite und Höhe können nicht angegeben werden

2.2 Rand, Innenabstand und Rahmen sind in vertikaler Richtung ungültig

2.3 Die linke Seite des Die Zeilenbox befindet sich in der Nähe der linken Seite des umschließenden Blocks, und die Linie Die rechte Seite einer Box ist bündig mit der rechten Seite der umschließenden Box, und zwischen der Kante des umschließenden Blocks und der Zeilenbox kann ein Float eingefügt werden .

2.4 Die Höhe der Inline-Box wird durch die Zeilenhöhe bestimmt.

Beispiele in diesem Abschnitt finden Sie im Inline-Element im Anzeigekapitel.

3. Die Lösung

basiert hauptsächlich auf dem BFC-Prinzip, da BFC die gesamte Fläche rendert und auch Breite und Höhe berechnet werden. Dies ist auch die legendäre Lösung zum Löschen von Floats

3.1 Methode zum Erstellen von BFC im übergeordneten Container

3.1.1 Methode zum Erstellen von BFC

a) Andere Float-Werte als keine;

b) Überlaufwerte außer sichtbar

c) Anzeigewerte sind Tabellenzelle, Tabellenüberschrift, Inline-Block, Flex, Inline-Flex usw .

d) Positionswert ist absolut, fest

e) Fieldset-Element

3.1.2 Float löschen

a) Float、overflow、display三种方式都可以清除浮动,但position、fieldset虽然创建了bfc但不可以清除浮动(也就是不能解决高度塌陷的问题)。主要原因为:position、fieldset都需要子元素来撑开父容器的高度,但子元素浮动后又不存在高度,所以失效。

b) Float、overflow、display示例代码:

.wrap{
            background: gray;
            padding: 10px;
            overflow: auto;
        }
        .left, .right{
            background: red;
            float: left;
            width: 200px;
            height: 100px;
        }
        .right{
            background: yellow;
        }
        .footer{
            background: pink;
        }
Nach dem Login kopieren
<div class="wrap" >
        <div class="left">left</div>
        <div class="right">right</div>
    </div><div class="footer">footer</div>
Nach dem Login kopieren

Vertiefendes Verständnis und Anwendung von Float-Eigenschaften

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;
        }
Nach dem Login kopieren
<div class="wrap" >
        <div class="left">left</div>
        <div class="right">right</div>
        <div class="clear"></div>
    </div>
<div class="footer">footer</div>
Nach dem Login kopieren

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;
        }
Nach dem Login kopieren
<div class="wrap" >
        <div class="left">left</div>
        <div class="right">right</div> 
    </div>
    <div class="footer">footer</div>
Nach dem Login kopieren

4. 总结

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

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

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

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

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


Verwandte Etiketten:
css
Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage