浮动的清除
为什么要清除浮动
- 浮动后的元素不会撑开父元素的高度,因为浮动是不占位置的。
- 清除浮动所带来的影响,并不是真正的清除浮动。
如何清除浮动
-
额外标签法:在浮动元素的后边加上标签
-
<div style="clear: left;"></div>
-
清除左浮动 clear: left
-
清除右浮动 clear: right
-
清除左右浮动 clear: both
-
优点:通俗易懂,书写方便
-
缺点:添加了额外的标签,结构化差
-
overflow 属性:在父元素中添加
-
overflow: hidding;
-
overflow:scroll;
-
overflow:auto;
-
优点:代码简洁
-
缺点:盒子中多余的内容会被隐藏掉
-
使用 after 伪元素清除浮动:在父元素中添加
-
.____::after { content:' ';display:block;clear:both;}
-
优点:符合闭合浮动思想、结构语义话正确
-
缺点:IE6-7 不支持 :after
-
双伪元素清除浮动:给父元素添加 after 以及 before 伪元素
-
.____::after, .____::before { content: ' ';display: table;clear: both;}
-
优点:代码简洁
-
缺点:IE6-7 不支持 :after