欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

margin的两个有趣现象:margin合并和margin塌陷

程序员文章站 2022-03-06 10:31:14
margin合并 当两个元素在垂直方向并列,分别设置margin值时会发生一个margin合并的现象 举个例子,有两个div,垂直并列,box1设置margin-bottom:20px,box2设置margin-top:50px, 按照一般的思维,这两个div之间的距离就应该是70px,事实并非如此 ......

margin合并

当两个元素在垂直方向并列,分别设置margin值时会发生一个margin合并的现象

举个例子,有两个div,垂直并列,box1设置margin-bottom:20px,box2设置margin-top:50px,

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>test</title>
    <style type="text/css">
    *{
        margin:0;
        padding: 0;
    }
    div{
        width: 50px;
        height: 50px;
    }
    #box1{
        margin-bottom: 20px;
        background: red;
    }
    #box2{
        margin-top: 50px;
        background: blue;
    }
    </style>
</head>
<body>
    <div id="box1"></div>
    <div id="box2"></div>
</body>
</html>

按照一般的思维,这两个div之间的距离就应该是70px,事实并非如此,两个div之间的距离只有50px,因为两个div的margin重叠,它会取最大值

margin的两个有趣现象:margin合并和margin塌陷               margin的两个有趣现象:margin合并和margin塌陷

 

一般来说margin合并不常见,因为只需设置一个div的margin来达到二者之间的距离就可以了

margin塌陷

margin塌陷很常见,存在于嵌套关系的盒子之间。

有两个div,box1包含box2,给box2一个margin-top:20px,让box2和box1之间产生20px的距离

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <title>test</title>
    <style type="text/css">
    *{
        margin:0;
        padding: 0;
    }
    #box1{
        width: 100px;
        height: 100px;
        background: red;
    }
    #box2{
        width: 50px;
        height: 50px;
        margin-top: 20px;
        background: blue;
    }
    </style>
</head>
<body>
    <div id="box1">
        <div id="box2"></div>
    </div>
</body>
</html>

结果会发现box1和box2没产生距离,反而是box1带着box2离页面顶端20px

margin的两个有趣现象:margin合并和margin塌陷           margin的两个有趣现象:margin合并和margin塌陷

解决办法:

  1. 给父级盒子设置overflow:hidden
  2. 给父级盒子设置border
  3. 给父级盒子设置padding