BFC是什么?

126 阅读1分钟

英文名称?

  • BFC全称是Block Formatting Context,即块格式化上下文。

如何触发BFC?

  • 浮动(元素的float不为none);
  • 绝对定位元素(元素的position为absolute或fixed)
  • 行内块inline-blocks(元素的display:inline-block)
  • 表格单元格(元素的display:table-cell,HTML表格单元格默认属性);
  • overflow的值不为visible;
  • 弹性盒flex boxes(元素的display:flex或者inline-flex) 最常见的触发BFC的形式就是:overflow:hidden、float:left/right、position:absolute。也就是说,每次看到这些属性,就代表该元素创建了一个BFC.

解决了什么问题?

  • 1.清除浮动,解决使用Float脱离文档流,高度塌陷的问题;
  • 2.防止与浮动元素重叠,;
  • 3.防止margin边距重叠

用display:flow-root,来触发BFC,就没有任何问题了。