关于BFC

一、 BFC 定义

BFC(Block formatting context)块级格式化上下文:

  • 文档根元素 <html> 是 BFC。
  • floatabsolutefixed定位,非块盒(block)的块容器(inline-blockstable-cellstable-captions)和 overflow 不为 visible 的块盒,会建立新的 BFC。

处在同一块级格式化上下文中的元素,比如h1、p会遵从一些规则:

  1. 元素会从上到下排列
  2. 另外元素和元素之间,如果有margin,会产生合并,比如一个下margin和下一个元素的上margin合并而一旦使用了开头所属的元素,则会建立新的块级格式化上下文(BFC), 不再受上一个容器的影响,有了自己的那套格式化规则,有自己的浮动。

二、BFC特性和作用

1. BFC会阻止垂直外边距合并:
只有同在一个BFC时,两个元素才会有可能发生垂直方向上的margin的重叠,这种元素包括相邻元素,嵌套元素,只要他们之间没有阻挡(例如border、非空内容,padding等),就会发生margin重叠。
因此只要让它们不再同一个BFC就行了。对相邻元素意义不大,嵌套元素很有必要建立新的BFC。
2. BFC不会重叠浮动元素:
可用来清除浮动.
3. BFC可以包裹住内部元素(爸爸管儿子),包括浮动元素:
父容器触发了BFC,便可以包含子元素的浮动(当然,浮动本身也能触发BFC)。
根元素<html>是BFC,如果不创建额外的BFC来包住浮动子元素,总会被根元素兜住的。所以浮动元素的父元素可能高度坍塌,但你从没见过 <html> 元素会因为内部元素浮动而坍塌,就是因为根元素是 BFC。
4. BFC能包含内部所有内容,除非儿子自己又成为BFC,那么爷爷就管不到孙子了。

三、display: flow-root

此属性是最新的CSS属性,专门用来解决以上各种为了创建BFC而引出副作用的问题,可以一键创建BFC,其他啥都不干。

四、总结

  1. 爸爸管儿子(比如清除浮动)
  2. 兄弟之间划清界限(比如两栏布局 float+bfc)

用BFC的特性清除浮动,总归都会有副作用,相对来说 overflow 副作用最小,但依然会影响后面相邻元素的显示,所以清除浮动就老老实实用 clearfix,否则错上加错,男上加男。没有任何场景必须要用BFC,除了面试!

参考链接

前端精选文摘:BFC 神奇背后的原理
MDN :Block formatting context

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,826评论 1 92
  • 1.在什么场景下会出现外边距合并?如何合并?如何不让相邻元素外边距合并?给个父子外边距合并的例子。 在CSS中,两...
    尹萨萨阅读 909评论 0 2
  • 什么是BFC bfc( 块级格式化范围 )是web页面中盒模型布局的CSS渲染模式,他决定了元素如何对其内容进行定...
    sakatayui酱阅读 232评论 0 0
  • 先前在学习CSS float时,有同学提到了BFC这个词,作为求知好问的好学生,哪里不懂查哪里,那么今天就来研究一...
    这名字真不对阅读 6,582评论 3 19
  • BFC 是什么? 首先BFC(Block Formatting Contexts)中文是块级格式化上下文。BFC是...
    1w1ng阅读 417评论 0 0