clearfix(清除浮动)

clearfix(清除浮动)一 浮动的概念浮动的框可以向左或向右移动 直到它的外边缘碰到包含框或另一个浮动框的边框为止 由于浮动框不在文档的普通流中 所以文档的普通流中的块框表现得就像浮动框不存在一样 二 浮动的影响 1 浮动会导致父元素高度坍塌父元素中有子元素 并且父元素没有设置高度 子元素在父元素中浮动 结果必然是父元素的高度为 0 这也就导致了父元素高度塌陷问题 浮动脱离文档流 这个问题会对整个

一、浮动的概念



二、浮动的影响

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

clearfix(清除浮动)

父元素中有子元素,并且父元素没有设置高度,子元素在父元素中浮动,结果必然是父元素的高度为0,这也就导致了父元素高度塌陷问题。

浮动脱离文档流,这个问题会对整个页面布局带来很大影响,如何解决高度坍塌问题,我们需要清除浮动。

三、浮动的清除

1. clear属性的空标签

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

 
    

,并且在CSS中设置

.clear{clear:both;}

即可清理浮动。

clearfix(清除浮动)

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

2. :after伪元素

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

clearfix(清除浮动)

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

转自WEBING的博客

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/226638.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月16日 下午10:28
下一篇 2026年3月16日 下午10:28


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号