Heim > Artikel > Web-Frontend > CSS-Float
Standarddokumentfluss
Teilen Sie das Formular von oben nach unten in Zeilen auf und ordnen Sie die Elemente in jeder Zeile von links nach rechts an. Dies ist der Dokumentfluss, den jedes nicht schwebende Element auf Blockebene einnimmt Eine Zeile und schwebende Elemente schweben an einem Ende der Zeile nach Bedarf. Wenn die aktuelle Zeile nicht passt, wird eine neue Zeile verschoben.
Mikroskopische Phänomene des Standardflusses
Phänomen der leeren Faltung
Gleiches gilt für Bilder und Formularelemente, die als Text betrachtet werden können
Die Höhe ist uneben und die Unterseite ist uneben. Die Kantenausrichtung
wird automatisch umgebrochen. Wenn Sie nicht in einer Zeile schreiben können, brechen Sie um
Elemente auf Blockebene und Inline-Elemente
Elemente auf Blockebene
belegen eine Zeile und können nicht mit anderen Elementen nebeneinander gestellt werden
Sie können die Breite und festlegen Wenn die Breite nicht festgelegt ist, wird die Breite standardmäßig auf 100 % des übergeordneten Elements eingestellt.
Inline-Elemente
werden neben anderen Inline-Elementen platziert
Die Breite und Höhe kann nicht festgelegt werden. Die Standardbreite ist die Breite des Textes.
Tag-Klassifizierung
In HTML können Tags unterteilt werden in: Textebene und Containerebene.
Textebene: p, span, a, b, i, u, em
Containerebene: p, h series, li, dt, dd
CSS-Klassifizierung It ist dem Obigen sehr ähnlich, mit Ausnahme von p:
Alle Tags auf Textebene sind Inline-Elemente, mit Ausnahme von p, das ein Element auf Textebene, aber ein Element auf Blockebene ist.
Alle Tags auf Containerebene sind Elemente auf Blockebene.
Konvertierung zwischen Elementen auf Blockebene und Inline-Elementen
Elemente auf Blockebene können auf Inline-Elemente gesetzt werden, und Inline-Elemente können auf Elemente auf Blockebene gesetzt werden
display: inline;/*块级元素转为行内元素*/
Sobald eine p-Einstellung erfolgt ist, können die Breite und Höhe dieses p nicht mehr festgelegt werden. Dieses p wird dann sofort zu einem Inline-Element. Zu diesem Zeitpunkt unterscheidet es sich nicht von einem Span, und dieses p kann neben anderen Tags platziert werden.
display: block;/*行内元素转为块级元素*/
Sobald display: block; auf eine Spanne festgelegt ist, wird die Spanne zu einem Element auf Blockebene. Zu diesem Zeitpunkt unterscheidet sich diese Bezeichnung nicht von einem p. Zu diesem Zeitpunkt kann die Spanne eine Zeile einnehmen, und andere dürfen nicht nebeneinander liegen ist nicht gesetzt, es wird den Vater ausfüllen.
display: inline-block;/*元素既能并排,又能设置宽高*/
标准文档流无法布局,所以需要元素脱离文档流,css中一共有三种手段,使一个元素脱离标准文档流:
浮动
浮动的三个性质
浮动的元素脱离标准文档流
.p1{ float: left; width: 100px; height: 100px; background-color: red; } .p2{ width: 150px; height: 150px; background-color: green; }我是p1我是p2
效果如下:p1浮动之后,脱离了标准文档流,p2就是标准文档流中的第一个盒子,所以就渲染在了页面的左上方。
浮动之后,一个span标签不需要转成块级元素,就能够设置宽度、高度了。所以能够证明一件事儿,就是所有标签已经不区分行内、块了。也就是说,一旦一个元素浮动了,那么将能够并排了,并且能够设置宽高了。无论它原来是个p还是个span。参考浮动的第一个图。
浮动的元素互相贴靠
body{font-size: 60px;} .p1{float: left;width: 100px;height: 100px;background-color: red;} .p2{float: left;width: 150px;height: 150px;background-color: green;} .p3{float: left;width: 200px;height: 200px;background-color: blue;}123
如果有足够空间,那么p3就会靠着p2。如果没有足够的空间,那么p3会靠着p1,如果没有足够的空间靠着p1,自己去贴页面左边。
浮动的元素有“字围”效果
p{float: left;width: 320px;height: 320px;background-color: orange;} 此处省略一万字
p挡住了p,但是p中的文字不会被挡住,形成“字围”效果。
浮动的清除
先看看不清除浮动的效果
Document ul {list-style: none; } li { float: left;margin-left: 5px;padding: 0;} .p1 li {background-color: red;} .p2 li {background-color: green; } 园子 新闻 博问 首页 精华 候选
本想让p1和p2分成两行显示,但是结果显示在了一行,第二组中的第1个li,去贴靠第一组中的最后一个li了。看看两个p的高度,显示为0,原因就是因为p没有高度,不能给自己浮动的子元素们一个容器。
清除浮动方法
清除浮动方法1.给浮动的元素的祖先元素加高度
如果一个元素要浮动,那么它的祖先元素一定要有高度,有高度的盒子,才能关住浮动。只要浮动在一个有高度的盒子中,那么这个浮动就不会影响后面的浮动元素。所以就是清除浮动带来的影响了。
上面的代码,为了让p1浮动的子元素不影响p2,给p1增加 .p1{height: 50px;} 或者给p1的任何一个父级加上高度就达到了想要的结果。
网页制作中,高度height很少出现。因为能被内容撑高(浮动的元素不能撑高父元素),所以这种清除浮动的方法不太适用。
清除浮动方法2:clear:both;
clear:both; 清除左右浮动,这种方法有一个非常大的问题,margin失效了。
Document ul{list-style: none;} li{float: left;margin-left: 5px;padding: 0;background-color: green;} .p1{margin-bottom: 100px;}/*margin失效*/ .p2{margin-top: 100px;clear:both;}/*margin失效*/ 园子 新闻 博问 首页 精华 候选
清除浮动方法3:隔墙法
外墙法
Document ul{list-style: none;} li{float: left;margin-left: 5px;padding: 0;background-color: green;} .p1{margin-bottom: 100px;}/*margin失效*/ .both { clear: both;margin-top:100px; }/*margin失效*/ .h10{height:10px;} 园子 新闻 博问 首页 精华 候选
margin仍然失效,但是可以给
设置高度,充当margin效果。
内墙法
放到p1的内部,好处是内容可以撑出父级的高了,margin也不会失效了。
Document ul{list-style: none;} li{float: left;margin-left: 5px;padding: 0;background-color: green;} .both { clear: both; } .h10{height:10px;} 园子 新闻 博问 首页 精华 候选
清除浮动方法4:overflow:hidden;
一个父元素不能被自己浮动的子元素撑出高度。但是只要给父级元素加上 overflow:hidden ; 父亲就能被子元素撑出高了。
IE6不支持用 overflow:hidden;来清除浮动的,解决办法是追加一条 _zoom:1;
Document ul{list-style: none;} li{float: left;margin-left: 5px;padding: 0;background-color: green;} .p1{overflow:hidden;} 园子 新闻 博问 首页 精华 候选