css-清除浮动
1.定义:
在非IE浏览器中,当容器的高度为auto,且容器的内容中有浮动(float为left或right)的元素,在这种情况下,容器的高度不能自动伸长以适应内容的高度,使得内容溢出到容器外面而影响(甚至破坏)布局的现象。为了防止这种现象出现的处理即为清除浮动。
2.清除浮动方法:
①使用带clear属性的空元素
在浮动元素后使用一个空元素如<div class="clear"></div>
,并在CSS中赋予.clear{clear:both;}
属性即可清理浮动。亦可使用<br class="clear" />或<hr class="clear" />
来进行清理。
优点:简单,代码少,浏览器兼容性好。
缺点:需要添加大量无语义的html元素,代码不够优雅,后期不容易维护。
②使用CSS的overflow属性
给浮动元素的容器添加overflow:hidden;
或overflow:auto;
可以清除浮动,另外在 IE6 中还需要触发 hasLayout ,例如为父元素设置容器宽高或设置 zoom:1。在添加overflow属性后,浮动元素又回到了容器层,把容器高度撑起,达到了清理浮动的效果。
③给浮动的元素的容器添加浮动
使其整体浮动,影响布局,不推荐使用。
④使用邻接元素处理
给浮动元素后面的元素添加clear属性。
⑤使用CSS的:after伪元素
给浮动元素的容器添加一个clearfix的class,然后给这个class添加一个:after伪元素实现元素末尾添加一个看不见的块元素(Block element)清理浮动。
.news {
background-color: gray;
border: solid 1px black;
}
.news img {
float: left;
}
.news p {
float: right;
}
.clearfix:after{
content: "020";
display: block;
height: 0;
clear: both;
visibility: hidden;
}
.clearfix {
/* 触发 hasLayout */
zoom: 1;
}
<div class="news clearfix">
<img src="news-pic.jpg" />
<p>some text</p>
</div>
总结:
清除浮动主要有两种方法:
一是利用 clear 属性,包括在浮动元素末尾添加一个带有 clear: both 属性的空 div 来闭合元素,其实利用 :after 伪元素的方法也是在元素末尾添加一个内容为一个点并带有 clear: both 属性的元素实现的。
二是触发浮动元素父元素的 BFC (Block Formatting Contexts, 块级格式化上下文),使到该父元素可以包含浮动元素,关于这一点。
上一篇: jQ事件
下一篇: 页面自适应(media)
推荐阅读
-
PHP实现清除wordpress里恶意代码,wordpress恶意代码_PHP教程
-
如何让一个DIV浮动在另一个DIV上面
-
清除浮动4-插入多余的div_html/css_WEB-ITnose
-
CSS浮动(float,clear)通俗讲解_html/css_WEB-ITnose
-
用MySQL函数清除字符串首尾空白字符的方法
-
IE6右浮动与margin-right无效(100分悬赏)_html/css_WEB-ITnose
-
jQuery(1.6.3) 中css方法对浮动的实现缺陷分析_jquery
-
IE浮动边界BUG延伸探讨
-
总结css清除浮动的几种方法及兼容性处理方法
-
清除Android工程中没用到的资源