天天看点

CSS(09)CSS外边距margin合并

外边距margin合并:

当两个垂直外边距相遇时,它们将形成一个外边距。合并后的外边距的高度等于两个发生合并的外边距的高度中的较大者。

折叠的结果

  1. 两个相邻的外边距都是正数时,折叠结果是它们两者之间较大的值。
  2. 两个相邻的外边距都是负数时,折叠结果是两者绝对值的较大值。
  3. 两个外边距一正一负时,折叠结果是两者的相加的和。

产生折叠的原因

  而根据w3c规范,两个margin是邻接的必须满足以下条件

  1、必须是处于常规文档流(非float和绝对定位)的块级盒子,并且处于同一个BFC当中。

  2、没有线盒,没有空隙(clearance,下面会讲到),没有padding和border将他们分隔开

  3、都属于垂直方向上相邻的外边距,可以是下面任意一种情况:

    a:元素的margin-top与其第一个常规文档流的子元素的margin-top。

    b:元素的margin-bottom与其下一个常规文档流的兄弟元素的margin-top。

    c:height为auto的元素的margin-bottom与其最后一个常规文档流的子元素的margin-bottom。

    d:高度为0并且最小高度也为0,不包含常规文档流的子元素,并且自身没有建立新的BFC的元素的margin-top和margin-bottom。

注释:只有普通文档流中块框的垂直外边距才会发生外边距合并。行内框、浮动框或绝对定位之间的外边距不会合并。

出现的情况

1、当一个元素出现在另一个元素上面时,第一个元素的下外边距与第二个元素的上外边距会发生合并。请看下图:

CSS(09)CSS外边距margin合并

亲自试一试

2、当一个元素包含在另一个元素中时(假设没有内边距或边框把外边距分隔开),它们的上和/或下外边距也会发生合并。请看下图:

CSS(09)CSS外边距margin合并

尽管看上去有些奇怪,但是外边距甚至可以与自身发生合并。

3、假设有一个空元素,它有外边距,但是没有边框或填充。在这种情况下,上外边距与下外边距就碰到了一起,它们会发生合并:

CSS(09)CSS外边距margin合并

如果这个外边距遇到另一个元素的外边距,它还会发生合并:

CSS(09)CSS外边距margin合并

继续阅读