专栏首页HTML5学堂如何清除浮动

如何清除浮动

如何清除浮动

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

清除浮动后的效果:

未清除浮动后的效果:

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

<!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)

原文出处及转载信息见文内详细说明,如有侵权,请联系 yunjia_community@tencent.com 删除。

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

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

我来说两句

0 条评论
登录 后参与评论

相关文章

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

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

    HTML5学堂
  • JQuery选择器(中)

    HTML5学堂:在学习JQuery开发的时候,选择器有多种,而我们将接着介绍选择器的其他类型,希望对大家有帮助! 5.临近选择器: $("mix+mix"),选...

    HTML5学堂
  • 浮动之后的那些事儿 - 清浮动操作

    本文内容概要: 1 上周作业讲解 2 浮动之后的特性 3 如何清浮动 4 实例操作 上周我们讲解了如何去实现页面的简单布局,用了三种基本的CSS选择器来控制标签...

    HTML5学堂
  • 简单实用的纯CSS百分比圆形进度条代码解析/源码下载

    percircle是一款简单实用的纯CSS百分比圆形进度条插件。你不需要做任何设置,只需要按该圆形进度条插件提供的标准HTML结构来编写代码,就可以生成一个漂亮...

    用户5997198
  • 无缝滚动案例简单实现代码

    <!doctype html> <html> <meta charset="utf-8"> <head> <title></title> <st...

    用户1730674
  • 老雷PHP全栈开发教程之Vue基础教程

    Vue是一套用于构建用户界面的渐进式框架,Vue 的核心库只关注视图层,Vue通过数据驱动构建ui界面。

    老雷PHP全栈开发
  • jQuery第二十一篇 scrollTop

    用户7873631
  • flex 布局

    CSS3 为我们提供了一种可伸缩的灵活的 web 页面布局方式 flexbox 布局,它具有很强大的功能,可以很轻松实现很多复杂布局。可以简便、完整、响应式地实...

    Krry
  • jQuery第十三篇 内容选择器(:empty :parent :contains(text) :has(selector)

    用户7873631
  • CSS旋转魔方

     想不想做一个3D魔方,把儿子的照片放进去,外面是你,里面是他。本人从业至今,自诩是动画机器人,苦心钻研各种动画,精通CSS3、Canvas等,不管你要做什么,...

    我不是费圆

扫码关注云+社区

领取腾讯云代金券