正确理解CSS中的margin合并

作者: 白色鹈鹕鸟 | 来源:发表于2018-03-12 22:54 被阅读43次

前言

最近在学习很多开发过程中容易忽悠但是又很重要的知识点,很多时候用的少不代表它不重要,这里将它们写出来以记录,如果有写的不好的地方请指正。

概念

margin合并是指块级元素的上外边距与下外边距有时会合并为单个外边距,有两点需要理解。

  1. 在块级元素中,不包括浮动和绝对定位元素
  2. 只发生在和当前文档流方向的相垂直的方向上

场景

一、相邻兄弟元素margin合并

p { margin: 1em 0; }
<p>第一行</p>
<p>第二行</p>

因为第一行和第二行的元素合并在一起,所以他们的间距还是1rem,而并非上下相加。

二、父级和子元素

.div1 { margin-top: 10px; }
.div2 { margin-top: 10px; }
<div class="div1">
  <div class="div2"></div>
</div>

由于父级和子级元素的合并,所以顶部的margin为10px,而不是20px。

三、空级块元素的合并

div1 { overflow: hidden; }
div2 { margin: 1rem 0; }
<div class="div1">
  <div class="div2"></div>
</div>

这个<div>元素的margin-top和margin-bottom合并在一起,所以高度只有1rem。

解决方法

这里的解决方法我们分为三种情况来讨论,第一种就是解决兄弟元素之间的margin合并情况。
我们可以使用设置浮动元素来解决,例如:

p { 
  margin: 1em 0;
  float: left; 
}
<p>第一行</p>
<p>第二行</p>

第二种是父级和子元素之间的margin合并,我们使用overflow属性来解决,例如:

.div1 { 
  margin-top: 10px;
  overflow: hidden; 
}
.div2 { margin-top: 10px; }
<div class="div1">
  <div class="div2"></div>
</div>

当然,我们还可以通过设置父元素为块状格式化上下文元素、设置border、padding等方式来解决问题。
第三种情况就是空块级元素的合并,一般为空块级元素设置一个高度就能够避免margin合并的问题。

div1 { overflow: hidden; }
div2 { 
  margin: 1rem 0;
  height: 1rem; 
}
<div class="div1">
  <div class="div2"></div>
</div>

意义

CSS中的margin合并是为了更好地进行图文信息展示而设计的,为了保证图文信息排版的舒服自然。我们不仅要理解它们存在的意义,而且要合理的运用它们。

相关文章

  • 正确理解CSS中的margin合并

    前言 最近在学习很多开发过程中容易忽悠但是又很重要的知识点,很多时候用的少不代表它不重要,这里将它们写出来以记录,...

  • CSS之二三事

    CSS不正交 各属性间互相影响margin vs border:margin默认情况下会合并,如父子margin合...

  • 外边距合并的问题 及 相应的解决办法

    在网页布局中,有时需要设置css设置外边距(margin), 但是会出现css外边距合并(即重叠)的情况。什么是外...

  • CSS之margin合并

    一、背景 实际开发过程中,会遇到这样一种问题:上面一个div设置margin-bottom:10px,下面一个di...

  • cssmargin合并+浮动

    margin塌陷,通过改变css解决 margin合并,即兄弟元素a的下边界顶100,b的上边界顶100,但是二者...

  • css中的内外边距和背景

    css中margin、padding和background margin与padding margin常用代码有 ...

  • margin合并和塌陷的问题

    这一篇来说明一下css当中一些bug,这两个bug出现在margin属性上面,分别是margin合并和margin...

  • html css

    1.margin 塌陷,与margin合并 margin合并不解决,直接设置一个box的margin即可 marg...

  • css中的margin

    1)设置盒子与盒子之间的距离margin-bottom: 10px; 2)特点-->当两个盒子垂直显示的时候(水平...

  • margin的合并

    我们在给div设置margin属性的时候,会出现margin 合并的问题。 Q:什么是margin合并呢? A:我...

网友评论

    本文标题:正确理解CSS中的margin合并

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