CSS之 BFC(块级格式化上下文)--css学习笔记

104 阅读2分钟

CSS之 BFC(块级格式化上下文)--css学习笔记

一、BFC是什么?

BFC(Block Formatting Context),即块级格式化上下文,它是页面中的一块渲染区域,并且有一套属于自己的渲染规则。

BFC 可以简单的理解为某个元素的一个 CSS 属性,只不过这个属性不能被开发者显式的修改,拥有这个属性的元素对内部元素和外部元素会表现出一些特性,这就是BFC。

二、触发条件

  满足下列条件之一就可触发BFC

  •   根元素,即HTML元素
  •   float的值不为none
  •   overflow的值不为visible
  •   display的值为inline-block、table-cell、table-caption
  •   position的值为absolute或fixed   

三、渲染规则

渲染规则:

  • 内部的盒子会在垂直方向上一个接一个的放置
  • 对于同一个BFC的俩个相邻的盒子的margin会发生重叠,与方向无关。
  • 每个元素的左外边距与包含块的左边界相接触(从左到右),即使浮动元素也是如此
  • BFC的区域不会与float的元素区域重叠
  • 计算BFC的高度时,浮动子元素也参与计算
  • BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素,反之亦然

BFC目的是形成一个相对于外界完全独立的空间,让内部的子元素不会影响到外部的元素

四、应用场景

4.1 防止margin重叠(塌陷)

同一个BFC的俩个相邻的盒子的margin会发生重叠

4.2 清除内部浮动

BFC在计算高度时,浮动元素也会参与,生成BFC,则内部浮动元素计算高度时候也会计算

4.3 自适应多栏布局

参考资料:# [布局概念] 关于CSS-BFC深入理解面试官:谈谈你对BFC的理解?块格式化上下文