说明

上一篇文章,写BFC的时候,其实已经有了一种清除浮动的的方法了,但是为什么单独拎出来一章来写呢,主要是因为,上面的写法不太友好,不灵活,因此需要详细展开了解一下。

浮动的概念

浮动的框可以向左或向右移动,直到它的外边缘碰到包含框或另一个浮动框的边框为止。
由于浮动框不在文档的普通流中,所以文档的普通流中的块框表现得就像浮动框不存在一样

浮动的影响

浮动会导致父元素高度坍塌

浮动的清除

  • BFC清除浮动

    上一篇文章讲过的,给css添加添加overflow:hidden;overflow:auto;可以清除浮动。

  • clear属性的空标签

    在浮动元素后添加一个空标签

    ,并且在CSS中设置.clear{clear:both;},即可清理浮动。

    • 原理:添加一个空标签,利用CSS提高的clear:both清除浮动,让父元素可以自动获取到高度
    • 优点:简单,代码少,兼容所有浏览器
    • 缺点:增加页面的标签,造成结构的混乱
    • 建议:不推荐使用,此方法已经过时
  • :after伪元素

    给浮动元素的容器添加一个clearfix的class,然后给这个class添加一个:after伪元素实现元素之后添加一个看不见的块元素(Block element)清理浮动。

    • 原理:通过CSS伪元素在容器的内部元素之后添加一个看不见的空格“/20”或点“.” ,并且设置clear属性清除浮动。
    • 优点:浏览器支持较好
    • 缺点:clearfix这个class需要添加zoom: 1(触发haslayout),才能支持IE6和IE7浏览器
    • 建议:推荐使用,设置公共类,减少CSS代码