BFC 是什么
- BFC是块级格式化上下文
- BFC触发的条件:
- 根元素(
<html>)
- 浮动元素(元素的
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 计算值(Computed)不为 visible 的块元素
display 值为 flow-root 的元素
contain 值为 layout、content 或 paint 的元素
- 弹性元素(
display为 flex 或 inline-flex 元素的直接子元素)
- 网格元素(
display 为 grid 或 inline-grid 元素的直接子元素)
- 多列容器(元素的
column-count 或 column-width 不为 auto,包括 column-count 为 1)
column-span 为 all 的元素始终会创建一个新的BFC,即使该元素没有包裹在一个多列容器中。
- 可以解决一些问题,比如:
- 有一定的副作用,解决办法是:使用最新的
display: flow-root 来触发 BFC 就没有副作用了。在父级块中使用 display: flow-root 可以创建新的 BFC。