文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

CSS清除浮动的原因及方法

2024-04-02 19:55

关注

本篇内容介绍了“CSS清除浮动的原因及方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

清除浮动的原因

假设一个 div 内部有个浮动的 div,当内部 div 的高度要比外层的父级 div 高度大时,将会导致父级 div 高度无法随着内部 div 的高度自适应,这是由于浮动元素已经脱离了正常文档流,因此无法对父级元素产生影响。举例如下:

代码如下:


<style>
#a {
 width: 100px;
 border: 1px solid #ccc;
}
#b {
 height: 50px;
 float: left;
 border: 1px solid #ccc;
}
</style>
<div id="a">A
 <div id="b">B</div>
</div>

CSS清除浮动的原因及方法

此时,我们就需要手动来清除浮动。

加入空 div

这是我之前的做法,即在结尾处添加一个空的 div,并设置 clear: both 属性。

代码如下:


<style>
#a {
 width: 100px;
 border: 1px solid #ccc;
}
#b {
 height: 50px;
 float: left;
 border: 1px solid #ccc;
}
#clear {
 clear: both;
}
</style>
<div id="a">A
 <div id="b">B</div>
 <div id="clear"></div>
</div>

CSS清除浮动的原因及方法

这个方法看似简单,但是如果清除浮动的地方较多,会产生很多无意义的 div,对于整个 HTML 结构无疑是有弊端的。

设定父级 div 高度

这个方法有点 hard code,由于父级 div 无法高度自适应,因此我们可以直接给父级 div 设置一个固定的高度值,如上例,考虑到 border 的值,设定父级 div 高度为 52px。

代码如下:


<style>
#a {
 width: 100px;
 height: 52px;
 border: 1px solid #ccc;
}
#b {
 height: 50px;
 float: left;
 border: 1px solid #ccc;
}
</style>
<div id="a">A
 <div id="b">B</div>
</div>

 CSS清除浮动的原因及方法

这个方法很快速但也脆弱,一旦内部浮动元素高度发生变化就无效了,所以只能应用于高度固定的场景。

设定父级 div 属性 overflow

直接给父级 div 添加 overflow: hidden 或 overflow: auto 属性,这里以 overflow: hidden 为例。

代码如下:


<style>
#a {
 width: 100px;
 border: 1px solid #ccc;
 overflow: hidden;
}
#b {
 height: 50px;
 float: left;
 border: 1px solid #ccc;
}
</style>
<div id="a">A
 <div id="b">B</div>
</div>

 CSS清除浮动的原因及方法

这个看上去又简单又实用,但是你不能对父级 div 设置高度,一旦父级 div 设置了固定高度,那么浮动元素超出的部分也会被隐藏。

代码如下:


<style>
#a {
 width: 100px;
 height: 20px;
 border: 1px solid #ccc;
 overflow: hidden;
}
#b {
 height: 50px;
 float: left;
 border: 1px solid #ccc;
}
</style>
<div id="a">A
 <div id="b">B</div>
</div>

CSS清除浮动的原因及方法

当使用 overflow: auto 属性同时设定固定高度时效果为:

CSS清除浮动的原因及方法

设置父级 div 伪类 before && after

这个方法即问题中介绍的新方法,对父级 div 设置伪类 before 和 after 的值。

代码如下:


<style>
#a {
 width: 100px;
 border: 1px solid #ccc;
}
#a:before, #a:after {
 content: "";
 display: block;
 clear: both;
 height: 0;
 visibility: hidden;
}
#b {
 height: 50px;
 float: left;
 border: 1px solid #ccc;
}
</style>
<div id="a">A
 <div id="b">B</div>
</div>

 CSS清除浮动的原因及方法

这个方法应该是最佳方案,即不会产生无意义的空 div,同时当父级元素高度固定时并不会影响内部的浮动元素高度。但是唯一一点就是伪类的兼容性问题。对于低版本的 IE 浏览器我们可以使用:

代码如下:


#a {
 zoom:1
}

在阅读了 @ShingChi 兄推荐的这篇博文 - http://nicolasgallagher.com/micro-clearfix-hack/ 后,我们还可以进一步地简化代码如下:

代码如下:


<style>
#a {
 width: 100px;
 border: 1px solid #ccc;
}
#a:before, #a:after {
 content: "";
 display: table;
 clear: both;
}
#b {
 height: 50px;
 float: left;
 border: 1px solid #ccc;
}
</style>
<div id="a">A
 <div id="b">B</div>
</div>

“CSS清除浮动的原因及方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-前端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯