BFC(块级格式化上下文)的特点和应用场景

BFC(Block Formatting Context)的特点是元素拥有独立的渲染区域,元素内部的内容(边距,浮动元素等)不会影响到外部元素。

哪些情况下会触发BFC

  • 设置overflow属性,值不为visible
  • 设置float属性,值不为none
  • 设置position属性,值为absolute或fixed
  • 设置display属性,值为inline-block, table-cell, table-caption, flex, inline-flex, grid,或者inline-grid

BFC的典型应用场景: 解决块级元素的塌陷问题(Collapsing)

  1. 块级元素的垂直塌陷: 当两个相邻的块级元素拥有上下方向相邻的边距时(例如:上面的元素拥有margin-bottom值,下面的元素拥有margin-top值),此时上下元素之间的间隙不是两者边距之和,而是两者之中的值较大的一个
  2. 块级元素的包含塌陷: 当块级父元素没有boder,padding值,块级子元素有margin-top值时,子元素的margin-top值会在父元素的外部生效,也就是整个父元素区域会向下偏移,这个偏移值由子元素的margin-top值决定

此外,BFC还可以用于清除浮动带来的影响等

    原文作者:赵飞燕
    原文地址: https://segmentfault.com/a/1190000019543581
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞