BFC 是什么

155 阅读1分钟
  1. BFC是块级格式化上下文
  2. BFC触发的条件:
    • 根元素(<html>)
    • 浮动元素(元素的 float不是 none
    • 绝对定位元素(元素的 position 为 absolute 或 fixed
    • 行内块元素(元素的 display 为 inline-block
    • 表格单元格(元素的 display 为 table-cell,HTML表格单元格默认为该值)
    • 表格标题(元素的 display 为 table-caption,HTML表格标题默认为该值)
    • 匿名表格单元格元素(元素的 display 为 tabletable-row、 table-row-grouptable-header-grouptable-footer-group(分别是HTML table、row、tbody、thead、tfoot 的默认属性)或 inline-table
    • overflow 计算值(Computed)不为 visible 的块元素
    • display 值为 flow-root 的元素
    • contain 值为 layoutcontent 或 paint 的元素
    • 弹性元素(display为 flex 或 inline-flex 元素的直接子元素)
    • 网格元素(display 为 grid 或 inline-grid 元素的直接子元素)
    • 多列容器(元素的 column-count 或 column-width 不为 auto,包括 column-count 为 1
    • column-span 为 all 的元素始终会创建一个新的BFC,即使该元素没有包裹在一个多列容器中。
  3. 可以解决一些问题,比如:
    • 清除浮动
    • 防止 margin 合并
  4. 有一定的副作用,解决办法是:使用最新的 display: flow-root 来触发 BFC 就没有副作用了。在父级块中使用 display: flow-root 可以创建新的 BFC。