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...

相关推荐
我是天龙_绍2 小时前
浏览器指纹,一个挺实用的知识点
前端
theshy2 小时前
前端自制接口抓取工具:一键收集并导出接口列表
前端
wayne2142 小时前
跨平台开发框架全景分析:Flutter、RN、KMM 与腾讯 Kuikly 谁更值得选择?
前端
LuckySusu2 小时前
【js篇】JavaScript 对象创建的 6 种方式:从基础到高级
前端·javascript
LuckySusu2 小时前
【js篇】async/await 的五大核心优势:让异步代码像同步一样清晰
前端·javascript
艾雅法拉拉2 小时前
JS知识点回顾(1)
前端·javascript·面试
LuckySusu2 小时前
【js篇】Promise 解决了什么问题?—— 彻底告别“回调地狱”
前端·javascript
程序员海军2 小时前
如何让AI真正理解你的需求
前端·后端·aigc
passer9812 小时前
基于Vue的场景解决
前端·vue.js
用户458203153172 小时前
CSS过渡(Transition)详解:创建平滑状态变化
前端·css