Skip to content

CSS 清除浮动的三种方法

Posted on:May 22, 2017 at 11:48 AM

先上一个简单的例子

简单的例子

如图所示,图片被添加了 float:left 属性,实现了文字环绕效果.但是再给 div 加了 border 之后,我们发现图片并没有被包起来,也就是图片浮上来了一层,那么怎么解决这种情况,包住图片呢?

下面将介绍三种清除浮动的方法:

跟着试一试?

给空 div 加 clear

在 div 元素的最后,加一个空 div,并且加上 clear 属性,和绿色 border(border 大法好!). <div style="clear: left; border: 4px solid green"></div>

空div

我们发现绿色的空 div 把红色 div 的下边压到了图片以下,达到了我们清除浮动的效果. clear: left 在这里的意思是:有此样式的元素盒的左边不可以有浮动的元素.

clear 元素不明白点这里

使用伪类

和第一种方法的原理是一样的,只不过这次不需要每次清除浮动的时候都写一遍代码. 用伪类声明一个 css 属性,需要清除浮动的元素,加上就可以实现了,绿色环保. 在 css 中写入:

.clearfix::after {
  content: "";
  border: 4px solid green;
  clear: both;
  display: block;
}

然后在最外层 div 上加上 clearfix 类就可以实现了

伪类实现

overflow: hidden 清除浮动

给父元素加上 overflow: hidden 属性.

overflow: hidden

overflow: hidden 的意思是超出的部分要裁切隐藏掉,那么为什么会有清除浮动的效果呢?因为父元素没有声明高度,所以要把父元素中所有的元素高度计算出来,才能根据所计算的高度,超出高度的将被裁掉. 我们试试给父元素加一个 100px 的高度:

图片就被剪裁了

所以此方法是有适用范围的,父元素的高度必须是 auto,否则将不生效!