美文网首页
外边距折叠问题

外边距折叠问题

作者: 姜治宇 | 来源:发表于2023-07-25 17:59 被阅读0次

折叠外边距的大小,等于相邻边距中的最大值。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .t1{
            width:100%;
            height:20px;
            margin-bottom:10px;
            background:red;
        }
        .t2{
            width:100%;
            height:20px;
            margin-top:10px;
            background:blue;
        }

    </style>
</head>
<body>
    <div class="t1"></div>
    <div class="t2"></div>
</body>
</html>
1.png

可以看到,上下两个margin都是10px,按理叠加应该是20px,但实际是10px。
这种情况还好,但多个容器会存在多外边距折叠的问题。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .t1{
            width:100%;
            height:20px;
            margin-bottom:10px;
            background:red;
        }
        .t2{
            width:100%;
            
            margin-top:10px;
          
        }
        .t3{
            width:100%;
            height:20px;
            
            margin-top:20px;
            background:blue;
        }
    </style>
</head>
<body>
    <div class="t1"></div>
    <div class="t2">
        <div class="t3"></div>
    </div>
</body>
</html>
2.png

t3容器的margin-top为20px,居然跟外部的10px折叠了,取大值就是20px。
我们其实想要的是,这个margin-top为20px,只留在t2中,而不跟外部折叠。怎么办呢?

解决方案

1、对容器使用overflow:auto(非visible即可)。
2、在两个外边距之间加上边框border、或内边距padding。
3、浮动元素、内联块。
4、绝对定位或固定定位。
5、flex弹性布局。

相关文章

  • 外边距折叠 margin合拼 原理

    外边距折叠 margin合拼 外边距折叠(margin collapsing) 对于块级元素而言,其 上外边距 和...

  • 外边距折叠

    最近做项目遇到了外边距折叠的问题,做技术当然要知其然,知其所以然。外边距折叠(margin-collapsing)...

  • CSS外边距合并(塌陷/margin越界)

    原文 博客原文 大纲 1、什么是外边距合并?(折叠外边距)2、外边距带来的影响3、折叠的结果4、产生折叠的原因5、...

  • 外边距折叠

    上下的垂直外边距margin在同时存在时会发生外边距折叠。这意味着当一个元素的下边缘接触到另一个元素的上边缘时,只...

  • 深入CSS之外边距折叠(margin collapse)详解

    什么是外边距折叠 准确来说,外边距折叠应该叫垂直外边距折叠,因为只会发生在垂直方向上,而水平方向上不会发生。 对于...

  • Css—盒模型外边距折叠带来的影响

    MDN上外边距折叠的定义 块的上外边距margin-top和下外边距margin-bottom有时合并(折叠)为单...

  • 外边距合并

    块的顶部外边距和底部外边距有时被组合(折叠)为单个外边距,其大小是组合到其中的最大外边距,这种行为称为外边距塌陷(...

  • CSS外边距合并

    块的顶部外边距和底部外边距有时被组合(折叠)为单个外边距,其大小是组合到其中的最大外边距,这种行为称为外边距塌陷(...

  • 几个让你效率更高的CSS代码技巧

    1、注意外边距折叠 与其他大多数属性不同,上下的垂直外边距margin在同时存在时会发生外边距折叠。 这意味着当一...

  • 外边距合并

    块级元素的上外边距和下外边距有时会合并成一个外边距,其大小取其最大,我们称为外边距合并(或外边距折叠),注意浮动元...

网友评论

      本文标题:外边距折叠问题

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