如何清除浮动

如何清除浮动

大家都知道,浮动会对文档产生影响,具体来看看会对文档产生什么影响?

清除浮动后的效果:

未清除浮动后的效果:

实例代码(未清除浮动):

<!doctype html>
<html>
<head>
	<meta charset="UTF-8">
	<title>梦幻雪冰</title>
	<link rel="stylesheet" href="reset.css">
	<style>
		.main div {
			float: left;
			width: 200px;
			height: 200px;
			margin-right: 20px;
			background: #fcf;
		}
		.footer {
			width: 420px;
			height: 100px;
			background: red;
		}
	</style>
</head>
<body>
	<div class="wrap">
		<div class="main">
			<div>梦幻雪冰</div>
			<div>独行冰海</div>
		</div>
		<div class="footer"></div>	
	</div>
</body>
</html>

解析:页面开发的时候可以为父级标签添加固定高度,但是有时希望内容能够撑开高度(比如内容不固定的时候)。对于不浮动的元素来说,它们是能够撑开外部div的高度的,但是一旦浮动,元素脱离文档流,父级div就相当于没有了内容(上面的例子中类名为main的高度为0了)。这时是没有办法实现内容撑开高度的。此时需要进行清除浮动对布局造成的一系列影响,所以叫清浮动。(不要误解成把浮动清除了,元素就没有浮动了,不是同一概念)。

清除浮动有很多种,如何进行选择清除浮动了?

独行冰海博客中已经讲解了清除浮动的几种方法——http://blog.163.com/hongshaoguoguo@126/blog/static/1804698120131130959204/

梦幻雪冰今天给大家分享的是清浮动的具体代码实现,主要是帮助大家理解哪一种清除浮动比较好,辨析它们的优缺点而已。

一:空标签清浮动

<!doctype html>
<html>
<head>
	<meta charset="UTF-8">
	<title>梦幻雪冰</title>
	<link rel="stylesheet" href="reset.css">
	<style>
		.main div {
			float: left;
			width: 200px;
			height: 200px;
			margin-right: 20px;
			background: #fcf;
		}
		.footer {
			width: 420px;
			height: 100px;
			background: red;
		}
		.clear {
			clear: both;                        /*消除默认行高的影响*/
			height: 0;
		}
	</style>
</head>
<body>
	<div class="wrap">
		<div class="main">
			<div>梦幻雪冰</div>
			<div>独行冰海</div>
			<p class="clear"></p>
		</div>
		<div class="footer"></div>	
	</div>
</body>
</html>

注释:上面用p标签进行空标签清浮动,当然可以用别的标签;如果用行元素的话需要进行转化为块,块元素就没有必要转化啦。

二:br标签清除浮动

<!doctype html>
<html>
<head>
	<meta charset="UTF-8">
	<title>梦幻雪冰</title>
	<link rel="stylesheet" href="reset.css">
	<style>
		.main div {
			float: left;
			width: 200px;
			height: 200px;
			margin-right: 20px;
			background: #fcf;
		}
		.footer {
			width: 420px;
			height: 100px;
			background: red;
		}
	</style>
</head>
<body>
	<div class="wrap">
		<div class="main">
			<div>梦幻雪冰</div>
			<div>独行冰海</div>
			<!-- br标签自带的属性 -->
			<br clear="all" />
		</div>
		<div class="footer"></div>	
	</div>
</body>
</html>

三:父元素设置overflow:hidden

<!doctype html>
<html>
<head>
	<meta charset="UTF-8">
	<title>梦幻雪冰</title>
	<link rel="stylesheet" href="reset.css">
	<style>
		.main {
			overflow: hidden;
		}
		.main div {
			float: left;
			width: 200px;
			height: 200px;
			margin-right: 20px;
			background: #fcf;
		}
		.footer {
			width: 420px;
			height: 100px;
			background: red;
		}
	</style>
</head>
<body>
	<div class="wrap">
		<div class="main">
			<div>梦幻雪冰</div>
			<div>独行冰海</div>
		</div>
		<div class="footer"></div>	
	</div>
</body>
</html>

四:父元素设置overflow:auto

<!doctype html>
<html>
<head>
	<meta charset="UTF-8">
	<title>梦幻雪冰</title>
	<link rel="stylesheet" href="reset.css">
	<style>
		.main {
			overflow: auto;
		}
		.main div {
			float: left;
			width: 200px;
			height: 200px;
			margin-right: 20px;
			background: #fcf;
		}
		.footer {
			width: 420px;
			height: 100px;
			background: red;
		}
	</style>
</head>
<body>
	<div class="wrap">
		<div class="main">
			<div>梦幻雪冰</div>
			<div>独行冰海</div>
		</div>
		<div class="footer"></div>	
	</div>
</body>
</html>

五:父元素浮动

<!doctype html>
<html>
<head>
	<meta charset="UTF-8">
	<title>梦幻雪冰</title>
	<link rel="stylesheet" href="reset.css">
	<style>
		.main {
			float: left;
		}
		.main div {
			float: left;
			width: 200px;
			height: 200px;
			margin-right: 20px;
			background: #fcf;
		}
		.footer {
			width: 420px;
			height: 100px;
			background: red;
		}
	</style>
</head>
<body>
	<div class="wrap">
		<div class="main">
			<div>梦幻雪冰</div>
			<div>独行冰海</div>
		</div>
		<div class="footer"></div>	
	</div>
</body>
</html>

效果:

注释:使得与父元素相邻的元素的布局会受到影响(影响到了类名为footer的元素)。

六:父元素设置display:table

<!doctype html>
<html>
<head>
	<meta charset="UTF-8">
	<title>梦幻雪冰</title>
	<link rel="stylesheet" href="reset.css">
	<style>
		.main {
			display: table;
		}
		.main div {
			float: left;
			width: 200px;
			height: 200px;
			margin-right: 20px;
			background: #fcf;
		}
		.footer {
			width: 420px;
			height: 100px;
			background: red;
		}
	</style>
</head>
<body>
	<div class="wrap">
		<div class="main">
			<div>梦幻雪冰</div>
			<div>独行冰海</div>
		</div>
		<div class="footer"></div>	
	</div>
</body>
</html>

七:after 伪元素(不是伪类)

<!doctype html>
<html>
<head>
	<meta charset="UTF-8">
	<title>梦幻雪冰</title>
	<link rel="stylesheet" href="reset.css">
	<style>
		.main div {
			float: left;
			width: 200px;
			height: 200px;
			margin-right: 20px;
			background: #fcf;
		}
		.footer {
			width: 420px;
			height: 100px;
			background: red;
		}
		.clearfix:after {
			clear:both; 
			display:block;
			height:0;
			content:"\200B";
		}
		.clearfix { 
			*zoom:1; 
		}
	</style>
</head>
<body>
	<div class="wrap">
		<div class="main clearfix">
			<div>梦幻雪冰</div>
			<div>独行冰海</div>
		</div>
		<div class="footer"></div>	
	</div>
</body>
</html>

注释:reset.css文件里面已经写好了after伪元素清浮动,直接调用即可。

原文发布于微信公众号 - HTML5学堂(h5course-com)

原文发表时间:2015-04-27

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏用户2442861的专栏

CSS float浮动的深入研究、详解及拓展 一 一 一 一 一 一 一 一

       我们使用float浮动做了很多其本职工作以外的事情,于是我们会混淆,我们会回看不清float真正的面目。浮动真正的意义在哪里呢?要知道这个问题的答...

1171
来自专栏用户2442861的专栏

应不应该使用inline-block代替float

CSS布局创建网站,浮动绝对占据了很大的比例.大块区域如主内容及侧边栏,以及在其中的小块区域,都可以看到浮动的影子.这里浮动是唯一的解决方案吗?

2101
来自专栏大数据钻研

CSS中的浮动和清除浮动,梳理一下!

从业三年,项目无数,现在回过头来,想要把一些重要的知识用白话整理出来:这个东西是什么?怎样才是最佳实践?希望对自己知识体系有梳理作用, 也希望对大家有些许帮助。...

4927
来自专栏HTML5学堂

浮动元素margin-bottom失效 — IE6盒模型

HTML5学堂:虽然IE6慢慢的退出市场了,但是还是有必要了解一些兼容问题,让自己的知识有一个更好的沉淀。margin-bottom的bug是容器div的 'z...

3446
来自专栏我爱编程

初识HTML5

客观地讲,没有不好的技术,只有没有用好的技术。JavaScript 的坎坷遭遇让我不禁想起了另一种被人们滥用的技术:Adobe公司研发的 Flash。

1692
来自专栏别先生

HTML+CSS提升小实战

1 <html> 2 <head> 3 <meta http-equiv="Content-Type" content="text/html; ch...

7038
来自专栏华章科技

天天做饼图,你烦不烦?老板都看腻了!

好象也没毛病,也挺好看的。但是....所有人的图表都是这样做,怎能突出你的图表个性?还可以更好看?看看下面的水滴图表:

1002
来自专栏前端知识分享

第13天:页面布局实例-博雅主页

今天写了个简单的页面,再熟悉了一下div+css布局,写的还可以,以后还要多练习。此外还进一步学习了定位相关知识。

1651
来自专栏应用案例

揭开ps的神秘面纱——初步认识photoshop

在这个看脸的“世界”里 论软件的强大莫过于ps 堪称美图界“磨人的小妖精” 下面就让小编带大家伙了解一下神秘的它吧 1.什么是psPS(位图图像处理软件Phot...

2168
来自专栏HTML5学堂

各大公司移动端页面 - 导航的实现

HTML5学堂:伴随着科技的发展,出现了各种型号的手机,导致了HTML5移动端开发人员对页面的实现要求更高了。目前来说,移动端的实现方法没有一个统一的标准,大家...

4487

扫码关注云+社区

领取腾讯云代金券