清除浮动和BFC

网页布局,实现水平方向的布局,就会用到浮动,今天用一篇文章总结下如何解决元素浮动对原布局所带来的影响:

BFC:

BFC是块级格式化上下文,是一种显示渲染规则。
介绍
只有同属一个BFC时且两个元素之间没有阻挡时才会发生margin合并。阻止元素被浮动元素所覆盖。可以将浮动元素包含。

如何生成BFC

  1. 设置float为left或者right。
  2. 设置overflow为hidden、auto、scroll三者中的一种。
  3. 设置display为inline-block、table-caption、table-cell三者中的一种。
  4. 设置position为absolute或者fiexd。

BFC作用
清除浮动,为父元素创建BFC,可以让父元素包含子浮动元素
解决外边距合并问题
消除文字围绕float元素的效果。

浮动元素:

特征:脱离文档正常流,根据设置的浮动方式向左或向右浮动,直到遇到所处容器的的边框或其它浮动元素。
对父容器的影响:会使父容器高度塌陷;
对其它浮动元素的影响:会阻止其它浮动元素继续移动;
对普通元素的影响:普通元素就像感知不到浮动元素的存在,浮动元素会覆盖住普通元素;
对文字的影响:文字能够感知到浮动元素,会环绕浮动元素按顺序显示;

例子:

<head>
<style>
.ct{border:1px solid pink;}
.ct1{float:left;width:100px;background:red;}
.ct2{float:left;width:100px;background:green;}
</style>
</head>
<body>
<div class="ct clear">
  <div class="ct1"></div>
  <div class="ct2"></div>
</div>
</body>

解决办法:

  1. 增加空div。
    在浮动原色最下方加入一个空的div,并且设置这个div为clear:both;
    缺点:增加一个无用的div。
  1. 使用CSS属性为父元素创建一个BFC,利用BFC可以包含浮动元素的特性清除浮动元素。
    缺点:float可能会影响布局,position:absolute;可能得到的结果并不是自己想要的。
  1. 利用伪类:after清除。(推荐使用)
    .clearfix{
    zoom:1; /IE6、7*/
    }
    .clear{
    content:" ";
    display:block;
    clear:both;
    }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,815评论 1 92
  • 清除浮动的常用三种方式一、clear:both /left /right /none /inherit分别代表在元...
    加加大叔阅读 395评论 0 1
  • 一,浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动模型是一种可视化格式模型,浮动...
    DeeJay_Y阅读 907评论 0 4
  • relative:生成相对定位的元素,通过top,bottom,left,right的位置相对于其正常位置进行定位...
    zx9426阅读 976评论 0 2
  • 浮动,从诞生那天起,它就是个特别的属性——既为网页布局带来新的方法,却又随之产生一系列的问题。当然,随着时间的推移...
    郝特么冷阅读 860评论 0 6