如何清除浮动

如何清除浮动

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

清除浮动后的效果:

未清除浮动后的效果:

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

<!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 条评论
登录 后参与评论

相关文章

来自专栏小巫技术博客

Android开发随手记录-实现ListView单选设置item背景颜色和字体颜色

我们可以看到左边是一个listView,点击选中其中一项就会变成跟其他项不一样的背景颜色,字体颜色也会不一样,这样的效果怎么实现?

1053
来自专栏青枫的专栏

设置窗体居中坐标图解及示例代码

注意:   窗体相对于屏幕默认的坐标为屏幕原点(0, 0),   为了便于理解,将窗体默认的坐标设为(m/2, n/2),

582
来自专栏算法channel

Python-GUI|Tkinter模块

01 Tkinter Tkinter模块是Python的标准Tk GUI工具包的接口,它并不是必须掌握的,但是掌握一个Python的标准图形库还是非常有意思的...

3619
来自专栏Golang语言社区

【Go 语言社区】iframe去边框,无边框,使用大全

<iframe src=”you page’s url” width=”100″ height=”30″ frameborder=”no” border=”0″...

3417
来自专栏小灰灰

Css学习手册之基本篇

Css学习手册之基本篇 每次写前端都是一个痛苦的过程,总是静不下来,彻底的研究下前端的技术,导致每次套页面都是直接采用一些封装好的控件,而有时对这些样式不满意时...

3426
来自专栏小巫技术博客

A018-布局之TableLayout

表格布局,顾名思义像表格一样进行布局。我们通常配合TableRow一起使用,TableRow代表一行,有多少个TableRow就有多少行。

772
来自专栏大前端开发

微信小程序input组件type属性3个值的作用

从文档中可以看到,type属性有三个值:text, number,digit。当我们使用这三个属性值,并在微信web开发者工具中查看效果的时候,其实是看不出来有...

886
来自专栏运维小白

2.12 mv命令

mv介绍 mv = move mv 相当于把文件挪动地方,如果在同一个目录就是更改文件名 可以使用这个命令实现,移动到一个目录下,同时更改文件名 mv 同样,默...

17710
来自专栏GreenLeaves

SQL学习之数据列去空格函数

1、LTRIM()---去掉列值左边的空格  如下代码: select * from dbo.course where tno='t003' and cno='...

1885
来自专栏linux系统运维

环境变量PATH与cp,mv以及文档查看命令的用法

1645

扫码关注云+社区