CSS清除浮动方法总结
清除浮动的原因
假设一个 div 内部有个浮动的 div,当内部 div 的高度要比外层的父级 div 高度大时,将会导致父级 div 高度无法随着内部 div 的高度自适应,这是由于浮动元素已经脱离了正常文档流,无法对父级元素产生影响。举例如下
<style>
#a {
width: 100px;
border: 1px solid #c;
}
#b {
height: 50px;
float: left;
border: 1px solid #c;
}
</style>
<div id="a">A
<div id="b">B</div>
</div>
此时,我们就需要手动来清除浮动。
加入空 div
这是我之前的做法,即在结尾处添加一个空的 div,并设置 clear: both 属性。
<style>
#a {
width: 100px;
border: 1px solid #c;
}
#b {
height: 50px;
float: left;
border: 1px solid #c;
}
#clear {
clear: both;
}
</style>
<div id="a">A
<div id="b">B</div>
<div id="clear"></div>
</div>
这个方法看似简单,如果清除浮动的地方较多,会产生很多无意义的 div,对于整个 HTML 结构无疑是有弊端的。
设定父级 div 高度
这个方法有点 hard code,由于父级 div 无法高度自适应,我们可以直接给父级 div 设置一个固定的高度值,如上例,考虑到 border 的值,设定父级 div 高度为 52px。
<style>
#a {
width: 100px;
height: 52px;
border: 1px solid #c;
}
#b {
height: 50px;
float: left;
border: 1px solid #c;
}
</style>
<div id="a">A
<div id="b">B</div>
</div>
这个方法很快速但也脆弱,一旦内部浮动元素高度发生变化就无效了,所以只能应用于高度固定的场景。
设定父级 div 属性 overflow
直接给父级 div 添加 overflow: hidden 或 overflow: auto 属性,这里以 overflow: hidden 为例。
<style>
#a {
width: 100px;
border: 1px solid #c;
overflow: hidden;
}
#b {
height: 50px;
float: left;
border: 1px solid #c;
}
</style>
<div id="a">A
<div id="b">B</div>
</div>
这个看上去又简单又实用,你不能对父级 div 设置高度,一旦父级 div 设置了固定高度,那么浮动元素超出的部分也会被隐藏。
<style>
#a {
width: 100px;
height: 20px;
border: 1px solid #c;
overflow: hidden;
}
#b {
height: 50px;
float: left;
border: 1px solid #c;
}
</style>
<div id="a">A
<div id="b">B</div>
</div>
当使用 overflow: auto 属性设定固定高度时效果为
设置父级 div 伪类 before && after
这个方法即问题中介绍的新方法,对父级 div 设置伪类 before 和 after 的值。
<style>
#a {
width: 100px;
border: 1px solid #c;
}
#a:before, #a:after {
content: "";
display: block;
clear: both;
height: 0;
visibility: hidden;
}
#b {
height: 50px;
float: left;
border: 1px solid #c;
}
</style>
<div id="a">A
<div id="b">B</div>
</div>
这个方法应该是最佳方案,即不会产生无意义的空 div,当父级元素高度固定时并不会影响内部的浮动元素高度。唯一一点就是伪类的兼容性问题。对于低版本的 IE 浏览器我们可以使用
#a {
zoom:1
}
在阅读了 @ShingChi 兄推荐的这篇博文 - 后,我们还可以进一步地简化代码如下
<style>
#a {
width: 100px;
border: 1px solid #c;
}
#a:before, #a:after {
content: "";
display: table;
clear: both;
}
#b {
height: 50px;
float: left;
border: 1px solid #c;
}
</style>
<div id="a">A
<div id="b">B</div>
</div>
长沙网站设计
- 如何自己建一个网站 自己想建个网站,怎么建
- 如何制作网站免费建站 创建网站免费注册
- html简单网页代码 html简单网页代码超链接
- dreamweaver网页制作 dreamweaver网页制作模板
- 上海网站建设 上海网站建设制作微信
- 如何制作网站和网页 如何制作一个网页
- html网页制作代码大全 端午节html网页制作代码大
- app开发公司 app开发公司前十名
- html网页制作 html网页制作文字居中
- app制作一个需要多少钱 请人制作一个app多少钱
- 成都网站制作 成都网站制作维护
- 百度建一个网站多少钱 百度做个公司网站要多少
- html+css网页制作成品 web网页制作成品css+javascrip
- html网页制作案例 html网页设计案例
- html+css网页制作成品 web网页制作成品css+javascrip
- 个人网站模板 个人网站模板HTML