美文网首页
关于BFC的小结

关于BFC的小结

作者: 小鸡咯咯哒 | 来源:发表于2020-10-29 13:36 被阅读0次

    BFC是什么

    MDN的解释

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

    创建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 值不为 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,即使该元素没有包裹在一个多列容器中(标准变更,Chrome bug)。
    块格式化上下文包含创建它的元素内部的所有内容.

    BFC作用

    1.用 BFC 包住浮动元素。BFC内的元素不会乱跑。
    2.float+div做自适应两栏布局
    3.利用BFC避免margin重叠。(同一BFC容器内margin会重叠)

    相关文章

      网友评论

          本文标题:关于BFC的小结

          本文链接:https://www.haomeiwen.com/subject/rymkvktx.html