CSS专题之外边距重叠

前言

石匠敲击石头的第 7 次

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

什么是外边距重叠

块级盒子的垂直方向外边距相邻 时,就会发生外边距 重叠(合并) 现象,产生单个外边距并取其中最大的外边距。

⚠️ 注意:

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

嵌套外边距重叠

嵌套元素的垂直方向的外边距也会发生重叠,取其中最大值。

自身外边距重叠

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

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

html 复制代码
<p></p>

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

为什么会有外边距重叠

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

html 复制代码
<p>我是一段文本</p>
<p>我是一段文本</p>

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

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

避免外边距重叠

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

  • 给容器元素添加 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 会被忽略,因此不会发生重叠

参考文章

博客地址:github.com/wjw020206/b...

相关推荐
sen_shan29 分钟前
Vue3+Vite+TypeScript+Element Plus开发-04.静态菜单设计
前端·javascript·typescript·vue3·element·element plus·vue 动态菜单
旧识君1 小时前
移动端1px终极解决方案:Sass混合宏工程化实践
开发语言·前端·javascript·前端框架·less·sass·scss
吃没吃1 小时前
vue2.6-源码学习-Vue 核心入口文件分析
前端
Carlos_sam1 小时前
Openlayers:海量图形渲染之图片渲染
前端·javascript
XH2761 小时前
Android Retrofit用法详解
前端
鸭梨大大大1 小时前
Spring Web MVC入门
前端·spring·mvc
吃没吃2 小时前
vue2.6-源码学习-Vue 初始化流程分析 (src/core/instance/init.js)
前端
XH2762 小时前
Android Room用法详解
前端
木木黄木木2 小时前
css炫酷的3D水波纹文字效果实现详解
前端·css·3d
郁大锤3 小时前
Flask与 FastAPI 对比:哪个更适合你的 Web 开发?
前端·flask·fastapi