清除浮动的几种方法

2020.03.17 - 宅先生

    清除浮动主要为了解决父级元素因为子级浮动引起内部高度为0的问题。清除浮动之后,父级就会根据浮动的子盒子自动检测高度。父级有了高度,就不会影响下面的标准流了。

    清除浮动的方法:

    ①额外标签法(隔墙法)

通过在浮动元素末尾添加一个空的标签:<div style=”clear:both”></div>

    ②父级添加overflow属性方法

给父级添加:overflow为 hidden | auto | scroll 都可以实现。

    ③使用after伪元素清除浮动

.clearfix:after {
content: "";
visibility: hidden;
display: block;
clear: both;
height: 0;
}
.clearfix {
*zoom: 1; /* IE6、7 专有 */
}

代表网站: 百度、淘宝网、网易等。

    ④使用双伪元素清除浮动

.clearfix:before,
.clearfix:after {
content: "";
display: table;
}
.clearfix:after {
clear: both;
}
.clearfix {
*zoom: 1; /* 由于IE6-7不支持:after,使用zoom: 1触发hasLayout */
}

代表网站: 小米、腾讯等。

    清除浮动总结:

什么时候用清除浮动:父级没高度,子盒子浮动,影响到了下面布局,我们就应该清除浮动了。


- END -

各位看官,如果你觉得文章不错,请鼓励鼓励吧~~

相邻或嵌套块元素垂直外边距合并(塌陷)问题

使用margin定义块元素的垂直外边距时,可能会出现外边距的合并(塌陷)问题。

取消

您的支持,是我继续创作的动力!

扫码支持
人生百态皆无常,最是一颗感恩心

打开支付宝扫一扫,即可进行扫码打赏

所得打赏均用于域名续费、服务器租赁等维持平台正常运营的必要支出。

海报生成中...