如何清除浮动
大家都知道,浮动会对文档产生影响,具体来看看会对文档产生什么影响?
清除浮动后的效果:
未清除浮动后的效果:
实例代码(未清除浮动):
<!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
本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。
我来说两句