• 技术文章 >web前端 >css教程

    css清理浮动有什么作用?清理浮动的方法(介绍)

    青灯夜游青灯夜游2018-09-17 11:21:35原创3376
    在前端开发过程中,我们经常会使用到浮动(float),这个我们即爱又恨的属性。爱,是因为通过浮动,我们能很方便地进行布局; 恨,是因为浮动之后遗留下来太多的问题需要解决。本章给大家介绍css为何要清除浮动,以及如何清除浮动;让大家了解元素进行浮动之后会出现的问题,以及css消除浮动的几种方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

    一、为什么会出现浮动?

    浮动(float)产生的最根本的原因是为了实现文字环绕效果;后来有人发现用它来做布局挺不错的,可以弥补传统布局上的一些不足,挺方便的。

    二、为什么要清除浮动,css清理浮动有什么作用?

    浮动(float)可以控制浮动框左右移动,直到遇到另一个浮动框或者遇到它外边缘的包含框。浮动框不属于文档流中的普通流,当元素浮动之后,不会影响块级元素的布局,只会影响内联元素布局。此时文档流中的普通流就会表现得该浮动框不存在一样的布局模式。当包含框的高度小于浮动框的时候,此时就会出现“高度塌陷”:1.jpg

    上图中父元素撑开的高度是padding带来的效果,父元素没有设置高度。

    在父元素没有设置高度的情况下:

    显然这样设置浮动后出现了一些问题,比如:

    1. 父元素的margin受到影响,无法实现上下左右居中,

    2. 若没有给父元素设置高度,浮动后父元素的高度没有被撑开,那么父元素就不会在显示屏上显示。

    实例说明(背景色)

    没有清除浮动:

    2.jpg

    清除浮动后:

    3.jpg

    三、怎样清除浮动

    下面介绍css清除浮动的几个方法(实现上图效果):

    1.使用带clear属性的空元素

    使用空标签清除浮动:在需要清除浮动的父级元素内部的所有浮动元素后添加一个空标签(理论上可以是任何标签,但常用<div>和<p>)清除浮动,并为其定义CSS代码clear:both。

    代码实例:

    <!DOCTYPE html>
    <html>
    	<head>
    		<meta charset="UTF-8">
    		<title></title>
    		<style>
    			.demo{
    				width: 500px;
    				margin: 50px auto;
    				background-color: #CCCCCC;
    			}
    			.left{
    				width: 100px;
    				height: 100px;
    				float: left;
    				background-color: #21B4BB;
    			}
    			.right{
    				width: 100px;
    				height: 50px;
    				float: right;
    				background-color: #21B4BB;
    			}
    			.clear{
    				clear:both;
    			}
    		</style>
    	</head>
    	<body>
    		<div class="demo">
    			<div class="left">left</div>
    			<div class="right">right</div>
    			<div class="clear"></div>
    		</div>
    	</body>
    </html>

    优点:简单,代码少,浏览器兼容性好。

    缺点:需要添加大量无语义的html元素,代码不够优雅,后期不容易维护。

    2.使用CSS的overflow属性

    使用overflow清除浮动:只需在需要清除浮动的元素中定义CSS代码overflow:auto或overflow:hidden即可。

    代码实例:

    <!DOCTYPE html>
    <html>
    	<head>
    		<meta charset="UTF-8">
    		<title></title>
    		<style>
    			.demo{
    				width: 500px;
    				margin: 50px auto;
    				background-color: #CCCCCC;
    				overflow:hidden
    			}
    			.left{
    				width: 100px;
    				height: 100px;
    				float: left;
    				background-color: #21B4BB;
    			}
    			.right{
    				width: 100px;
    				height: 50px;
    				float: right;
    				background-color: #21B4BB;
    			}
    		</style>
    	</head>
    	<body>
    		<div class="demo">
    			<div class="left">left</div>
    			<div class="right">right</div>
    		</div>
    	</body>
    </html>

    优点:不存在结构和语义化问题,代码量极少

    缺点:内容增多时候容易造成不会自动换行导致内容被隐藏掉,无法显示需要溢出的元素

    3.使用CSS的:after伪元素

    对父元素使用:after伪元素,设置display:table

    display:table 使生成的元素以块级表格显示,占满剩余空间。

    通过content: " "生成内容作为最后一个元素,至于content里面是什么都是可以的,CSS经典的是 content:".",有些版本可能content里面内容为空。

    代码实例:

    <!DOCTYPE html>
    <html>
    	<head>
    		<meta charset="UTF-8">
    		<title></title>
    		<style>
    			.demo{
    				width: 500px;
    				margin: 50px auto;
    				background-color: #CCCCCC;
    				*zoom: 1;
    			}
    			.demo:after { 
    				content: " ";
    				display: table; 
    				clear: both;  
    			}  
    			.left{
    				width: 100px;
    				height: 100px;
    				float: left;
    				background-color: #21B4BB;
    			}
    			.right{
    				width: 100px;
    				height: 50px;
    				float: right;
    				background-color: #21B4BB;
    			}
    		</style>
    	</head>
    	<body>
    		<div class="demo">
    			<div class="left">left</div>
    			<div class="right">right</div>
    		</div>
    	</body>
    </html>

    缺点:适合现代浏览器,不支持IE6/7,*zoom: 1就是为了兼容IE6/7

    以上就是css清理浮动有什么作用?清理浮动的方法(介绍)的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:浮动 clear overflow :after css
    上一篇:分享四种方式将CSS样式导入到HTML中 下一篇:学习Bootstrap后的一点小总结
    Web大前端开发直播班

    相关文章推荐

    • html清除浮动的6种方法示例_CSS/HTML• CSS 浮动清理,不使用 clear:both标签_经验交流• 闭合浮动元素超级简单的方法_CSS/HTML• 页面图片浮动左右滑动效果的简单实现案例_javascript技巧

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网