头图

前言

石匠敲击石头的第 7 次

上一篇文章中有提到块级盒子有一个特点,垂直方向相邻的外边距(margin)会产生 重叠(合并) 现象,这也是在开发中会经常遇到的,所以就有了这篇文章,如果哪里写的有问题欢迎指出。

什么是外边距重叠

块级盒子的垂直方向外边距相邻时,就会发生外边距 重叠(合并) 现象。

  • 如果两个值都为正值,则取其中最大的外边距。
  • 如果一个正一个负,则取差值作为外边距。
  • 如果两个都为负,则取两个之中绝对值最大的作为外边距。

image-20250404135045382.png

⚠️ 注意:

  • 只有垂直方向的外边距会产生重叠,水平方向的外边距不会重叠。
  • 行内盒子垂直方向的外边距会被浏览器忽略,所以也就不会重叠。

嵌套外边距重叠

嵌套元素的垂直方向的外边距也会发生重叠。

image-20250404141437167.png

自身外边距重叠

当一个高度为 0px 的块级元素有上下的外边距时,顶部的外边距也会与底部的外边距发生重叠。

image-20250404142940683.png

这也就解释了为什么页面中有设置了垂直方向上的外边距的元素,内容为空时依旧会占用外边距空间的原因。

<p></p>

image-20250405084256261.png

在上面的基础上如果与另外一个块级元素的垂直外边距相邻时,外边距会继续重叠。

image-20250404154027525.png

为什么会有外边距重叠

外边距重叠是 CSS 规范中特意设计的行为,目的是为了简化布局计算,让相邻的块级元素垂直方向上的间距更自然。

<p>我是一段文本</p>
<p>我是一段文本</p>

例如上述这段 HTML 代码,<p> 元素是块级元素,浏览器的默认样式(用户代理样式)会为 <p> 元素添加上下的外边距,此时它们之间垂直方向上的间距是相同的(因为外边距重叠的原因)。

image-20250404155103369.png

可以想象,如果没有外边距重叠这个特性,还需要另外写代码来处理。

避免外边距重叠

在某些情况下,我们不希望块级元素垂直方向的外边距发生重叠,这时可以采用以下几种方法:

  • 给容器元素添加 overflow: auto(或者非 visible 的值 ),可以避免与内部子元素产生嵌套外边距重叠,该方法副作用最小。
  • 给容器元素添加边框或者内边距,以此来隔开内部子元素的外边距,避免产生嵌套外边距重叠。
  • 如果容器元素为浮动(float)、行内块(inline-block)、绝对定位或固定定位时,内部子元素不会和外部容器元素产生嵌套外边距重叠。
  • 当使用 Flexbox 布局或 Grid 布局时,内部的子元素之间不会发生垂直方向上的外边距重叠。
  • 当元素设置为 display: table-cell 时,外边距通常不会起作用,所以也不会发生垂直方向上的外边距重叠。table-row 和大多数表格相关的显示类型也是这样。但 tableinline-tabletable-caption 除外,它们的外边距还是会生效的。

⚠️ 注意: 这些方法部分会改变布局,除非能产生想要的布局,否则不要轻易使用。

总结

  • 外边距重叠是指相邻的块级元素垂直方向的外边距会重叠,重叠值计算逻辑如下

    • 如果两个值都为正值,则取其中最大的外边距
    • 如果一个正一个负,则取差值作为外边距
    • 如果两个都为负,则取两个之中绝对值最大的作为外边距
  • 有如下外边距重叠发生的条件

    • 相邻块级元素的垂直外边距
    • 嵌套块级元素的外边距
    • 同一元素的上下外边距(自身重叠)
  • 外边距重叠是出于 CSS 规范的设计,简化布局计算,让内容间距更自然
  • 有如下方法可以避免外边距重叠

    • 父元素设置 overflow 为非 visible(如 auto
    • 父元素添加边框或内边距
    • 使用浮动、绝对定位、inline-block 等布局方式
    • 使用 Flex 或 Grid 布局
  • 注意事项

    • 只有垂直方向外边距会重叠
    • 行内元素的垂直 margin 会被忽略,因此不会发生重叠

参考文章

博客地址:https://github.com/wjw020206/blog


CodePencil
8 声望0 粉丝

下一篇 »
CSS专题之BFC