一、块级格式化上下文 (Block Formatting Context)
BFC是一个独立的布局环境,其中的元素布局是不受外界的影响。
二、BFC的布局规则
1、内部的Box会在垂直方向,一个接一个地放置。
2、Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box会发生margin重叠。
3、每个元素的margin box的左边, 与包含块(元素的父节点)border box的左边相接触
4、BFC的区域不会与float box重叠。(现象:高度塌陷)
5、BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。
6、计算BFC的高度时,浮动元素也参与计算
三、满足下列条件之一就可触发BFC
【1】根元素,即HTML元素
【2】float的值不为none
【3】overflow的值不为visible
【4】display的值为inline-block
【5】position的值为absolute或fixed
四、bfc的作用:
1.自适应两栏布局
<style>
.aside{width:100px; height:150px; float:left; background:#f66;}
.main{height:200px; background:#fcc;overflow:hidden}
</style>
<body>
<div class=”aside”></div>
<div class=”main”></div>
</body>
2.可以阻止元素被浮动元素覆盖
3.可以包含浮动元素——清除内部浮动
4.分属于不同的BFC时可以阻止margin重叠