其他分享
首页 > 其他分享> > CSS 清除浮动

CSS 清除浮动

作者:互联网

为什么需要清除浮动

在一般情况下,一个盒子里使用了 CSS float 属性,导致父级盒子不能被撑开;

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title>清除浮动</title>
    <style type="text/css">
		.root {
			border: 2px solid;
			margin: 20px;
		}
		.item {
			width: 200px;
			height: 200px;
			border: 2px green solid;
			margin: 20px;
		}
		.item.left {
			float: left;
		}
		.item.right {
			float: right;
		}
    </style>
</head>
<body>
	<div class="root">
		<div class="item left"></div>
		<div class="item right"></div>
	</div>
</body>
</html>

效果图:
image
本来两个绿色对象盒子是在黑色盒子内,因为对两个绿色盒子使用了float浮动,所以两个黑色盒子产生了浮动,导致黑色盒子不能撑开;
副作用:由于父级盒子不能被撑开,导致父级盒子CSS背景不能显示,边框不能随内容撑开,margin、padding设置值而不能正确显示;

清除浮动的几种常见的作法

  1. clear: both;清除浮动:
    在父级元素结束标签前加一个空的div元素,给空元素设置clear: both;
<style type="text/css">
	.clear {
		clear: both;
	}
	/*剩余样式省略,参考文章开头*/
</style>

<div class="root">
	<div class="item left"></div>
	<div class="item right"></div>
	<div class="clear"></div>
</div>

效果图:
image
缺点:添加了不必要的空元素;
2. overflow: hidden;清除浮动:
给父级元素设置overflow:hidden;

<style type="text/css">
	.root {
		border: 2px solid;
		margin: 20px;
		overflow: hidden;
	}
	/*剩余样式省略,参考文章开头*/
</style>

<div class="root">
	<div class="item left"></div>
	<div class="item right"></div>
</div>

效果图:
image
缺点:内容增多的时候容易造成不会自动换行导致内容被隐藏掉,无法显示要溢出的元素;
3. ::after伪元素清除浮动:

<style type="text/css">
	.clear::after {
		height: 0;
		clear: both;
		content: "";
		display: block;
		visibility: hidden;
	}
	.clear {
		/*ie6清除浮动的方式 *号只有IE6-IE7执行,其他浏览器不执行*/
		*zoom: 1;
	}
	/*剩余样式省略,参考文章开头*/
</style>

<div class="root clear">
	<div class="item left"></div>
	<div class="item right"></div>
</div>

效果图:
image
缺点:ie6-7不支持伪元素::after,使用zoom:1触发hasLayout;

标签:浮动,盒子,父级,清除,clear,元素,CSS
来源: https://www.cnblogs.com/operate/p/15981723.html