美文网首页
从margin重叠到bfc

从margin重叠到bfc

作者: wwq2020 | 来源:发表于2020-09-24 11:18 被阅读0次

创建demo.html,内容如下

<style>
    #root {
        border: 2px solid black;
    }

    #test1 {
        height: 100px;
        width: 100px;
        background-color: red;
        margin: 50px;
    }

    #test2 {
        height: 100px;
        width: 100px;
        background-color: blue;
        margin: 50px;
    }
</style>

<div id="root">
    <div>
        <div id="test1"></div>
    </div>
    <div>
        <div id="test2"></div>
    </div>
</div>

open demo.html,看到如图


image.png

test1和test2的margin重叠了,其实是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)

解决办法就是,添加overflow:hidden

<style>
    #root {
        border: 2px solid black;
    }

    #test1 {
        height: 100px;
        width: 100px;
        background-color: red;
        margin: 50px;
    }

    #test2 {
        height: 100px;
        width: 100px;
        background-color: blue;
        margin: 50px;
    }
</style>

<div id="root">
    <div>
        <div id="test1"></div>
    </div>
    <div style="overflow:hidden">
        <div id="test2"></div>
    </div>
</div>

最终如图


image.png

相关文章

  • 从margin重叠到bfc

    创建demo.html,内容如下 open demo.html,看到如图 test1和test2的margin重叠...

  • BFC margin重叠

    BFC:块级格式化上下文,它是指一个独立的块级渲染区域,只有Block-level BOX参与,该区域拥有一套渲染...

  • 「css零碎」使用技巧

    1. 使用尽量使用padding代替margin因为BFC问题, margin上下有可能会重叠 2. positi...

  • 2019-07-24

    2.1 什么是BFC?垂直margin重叠是为什么?怎么解决这个问题? BFC是块级格式化上下文,相当于开辟了一块...

  • 什么是BFC

    平时的工作中我们都是使用过BFC(如清浮动,防止margin重叠等),但是相信还是有一部分人不清楚什么叫做BFC,...

  • 你不知道的 CSS 秘密:margin篇

    本篇讲解的是主要是BFC 可以解决的 margin 重叠问题 ,如对你有帮助 ,请点个赞给个鼓励,谢谢~ 先来一张...

  • margin重叠

    通常特性:1.block水平元素(不包括float和absolute元素)2.不考虑writing-mode,只发...

  • CSS解决外边距重叠和高度坍塌

    什么是外边距重叠: 当给子元素设置margin-top的时候 父元素会跟着移动 解决方法一 触发BFC 以下条件满...

  • css布局--左固定右自适应两栏布局

    默认结构: 可以利用以下方法达到左侧固定右侧自适应的效果: 利用BFC与浮动元素不重叠 利用浮动和margin-l...

  • 多列布局思路

    首先阅读:BFC与多列布局 通过BFC特性:float + BFC盒子 通过margin回拉(用到float)或绝...

网友评论

      本文标题:从margin重叠到bfc

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