zoukankan      html  css  js  c++  java
  • BFC 到底是什么?

    MDN 对 BFC 的描述:

    块格式化上下文(Block Formatting Context,BFC) 是Web页面的可视化CSS渲染的一部分,是布局过程中生成块级盒子的区域,也是浮动元素与其他元素的交互限定区域。

     

    往下接着看看:

    下列方式会创建块格式化上下文:

    • 根元素或包含根元素的元素
    • 浮动元素(元素的 float 不是 none)
    • 绝对定位元素(元素的 position 为 absolute 或 fixed)
    • 行内块元素 (元素的 display 为 inline-block)
    • 表格单元格(元素的 display 为 table-caption)
    • 具有overflow 且值不是 visible 的块元素,
    • display: flow-root
    • column-span: all 应当总是会创建一个新的格式化上下文,即便具有 column-span: all 的元素并不被包裹在一个多列容器中。

    好像有那么点意思,就是说如果符合以上情况,就会创建 BFC 咯?
    先不管那么多,写个demo试试看:

     
     

    上面代码,当我们给子元素一个高度时,父元素会将子元素包裹住。

     
     

    但是,当我们给子元素一个左浮动后,子元素脱离文档流就跑出去了。


     

    上面代码,当我们也给父元素加上一个左浮动后(满足 float 不为 none),触发了 BFC,成功创建了块格式化上下文,父元素重新包裹住了子元素。


     

    上面代码,当我们让父元素绝对定位后也触发了 BFC。

     

    上面代码满足元素的 display 为 inline-block的条件,所以触发了 BFC。

    再结合 MDN 的描述:

    创建了块格式化上下文的元素中的所有内容都会被包含到该BFC中

     

    这下就清楚多了,BFC 可以用来包住浮动元素(不是清除浮动哟)。就算子元素再怎么折腾,也不会影响外部元素了。

    话说回来,虽然我可以通过给父元素加 float 等条件触发 BFC,但是给父元素加 float 这个行为本身会不会影响别的元素呢?我可不想拆东墙补西墙。。。

    于是,一个新的属性display: flow-root诞生了!!!
    这个属性的功能就一个:触发 BFC

     

    只需给元素加上display: flow-root就能触发 BFC。

    既然说 BFC 能够包住浮动元素,那么我是不是可以利用这一点进行布局呢?

     

    上面代码,当slide-bar左浮时,会脱离文档流,和main发生重叠。你也许会说,给main也加个左浮吧,看代码:
     

    没错,由于没有宽度,我的main被挤扁了。。。那为什么不加个宽度呢?
    这样我的main就不能自适应了呀(敲黑板!)
    BFC 完美的解决了这个问题:
     

    上面代码,利用 BFC 使两个兄弟元素互不干涉,实现了左右自适应布局。

     

    总的来说,你可以这样理解 BFC:
    功能一:爸爸管儿子
    功能二:兄弟之间划清界限

    参考资料:
    块格式化上下文
    CSS深入理解流体特性和BFC特性下多栏自适应布局

  • 相关阅读:
    10分钟用JS实现微信 "炸屎"大作战
    基于nodejs 的多页面爬虫
    react+react-router 4.0+redux 构建购物车实战项目
    vue+websocket+express+mongodb实战项目(实时聊天)
    用vuejs仿网易云音乐(实现听歌以及搜索功能)
    js 实现 bind 的这五层,你在第几层?
    教你如何搭建一个自动化构建的博客
    vue-chat项目之重构与体验优化
    vue+websocket+express+mongodb实战项目(实时聊天)(二)
    css 多栏自适应布局
  • 原文地址:https://www.cnblogs.com/web-record/p/10315422.html
Copyright © 2011-2022 走看看