css外边距垂直合并

CSS 外边距垂直合并

何为外边距垂直合并?

当普通文档流的相邻元素设置了margin-top或margin-bottom时,垂直方向上的外边距会变成相邻元素中外边距较大的一个,而不是两个元素外边距之和。

例子

<!DOCTYPE html>
<html lang="zh-CN">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
        *{
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
        main{
            margin:150px;
            width: 300px;
            height: 300px;
        }
        div{
            width: 100px;
            height: 100px;
            background-color: rebeccapurple;
            color: white;
            font-size: 1.5em;
            background-clip: content-box;
            margin: 10px;
        }
    </style>
</head>
<body>
    <main>
        <div>1</div>
        <div>2</div>
        <div>3</div>
    </main>
</body>
</html>

按照常规理解,此处相邻的div在垂直方向上应该有10+10=20px大小的外边距,但是实际上相邻的div垂直方向上只有10px的外边距。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-xpSyyh3b-1642826454988)(C:\Users\liuxin\AppData\Roaming\Typora\typora-user-images\image-20220110151338727.png)]

总结

  • 外边距合并只发生在普通文档流的块级元素,行内元素或行内块级元素均不会发生,定位、浮动、弹性和栅格布局也不会发生
    边距合并只发生在普通文档流的块级元素,行内元素或行内块级元素均不会发生,定位、浮动、弹性和栅格布局也不会发生
  • 外边距合并只发生在垂直方向
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值