你正在用的BFC

在我们写页面的时候,其实不知不觉的用到了BFC属性,那你知道是怎么触发的吗?他的定义又是什么呢?

块格式化上下文(Block Formatting Context,BFC) 是Web页面的可视化CSS渲染的一部分,是块盒子的布局过程发生的区域,也是浮动元素与其他元素交互的区域。

通过下列方式会创建块格式化上下文

  • 根元素或包含根元素的元素
  • 浮动元素(元素的 float 不是 none
  • 绝对定位元素(元素的 position 为 absolute 或 fixed
  • 行内块元素(元素的 display 为 inline-block
  • 表格单元格(元素的 display为 table-cell,HTML表格单元格默认为该值)
  • 表格标题(元素的 display 为 table-caption,HTML表格标题默认为该值)
  • 匿名表格单元格元素(元素的 display为 table、table-row、 table-row-group、table-header-group、table-footer-group(分别是HTML table、row、tbody、thead、tfoot的默认属性)或 inline-table
  • overflow 值不为 visible 的块元素
  • display 值为 flow-root 的元素
  • contain 值为 layoutcontent或 strict 的元素
  • 弹性元素(display为 flex 或 inline-flex元素的直接子元素)
  • 网格元素(display为 grid 或 inline-grid 元素的直接子元素)
  • 多列容器(元素的 column-count 或 column-width 不为 auto,包括 column-count 为 1
  • column-span 为 all 的元素始终会创建一个新的BFC,即使该元素没有包裹在一个多列容器中(标准变更Chrome bug)。

块格式化上下文包含创建它的元素内部的所有内容.

已上是MDN对BFC的定义,下面举例说明BFC的应用

例1

.outter{
      overflow: hidden
}
.inner{
      width: 200px;
      height: 200px;
      backgrund: red;
      float: left
}
<div class='outter'>
     <div class='inner'> </div>
</div>

outer元素overflow:hidden开启了BFC属性,清除浮动带来的高度塌陷问题

例2

div{
   width: 200px;
   height: 200px;
   margin: 100px;
   background: red;
}
<div></div>
<div></div>

实际发现,两个div上下距离为100px,而非200px,因为两个div元素都处于同一个BFC容器下,所以第一个div的下边距和第二个div的上边距发生了重叠,所以两个盒子之间距离只有100px,而不是200px。

解决办法:分别使用开启了BFC属性的元素包裹

总结:开启了BFC属性的元素有如下特性

内部的Box会在垂直方向,一个接一个地放置;

Box垂直方向的距离由margin决定,同一个BFC下相邻两个Box的margin会发生重叠,例2

形成了BFC的区域不会与float box重叠,例如两个float:left元素

BFC在页面上是一个独立的容器,里外的元素不会互相影响,层叠按文档流排列,例如两个float:left元素内部有溢出的元素

对BFC的理解还比较浅显,更多应用等你发现

发表评论