css外边距重叠问题

前端开发过程中,是否碰到这样一个场景,同时设置了上部元素下边距和下部元素上边距,发现实际的边距竟然不是两个外边距之和,这就是我们这里讲的css 外边距重叠了

css外边距重叠通常发生在 block 块级元素中(flex、inline不会出现),且只包括上下边距,左右边距不会重叠

有三种场景会出现边距重叠问题:

场景一:两个子节点同时设置上下边距

出现了两个子节点,分上部元素下边距(margin-bottom)和下部元素上边距(margin-top),此时,两者边距会出现以下合并场景

  • 两者均为正、均为负,取绝对值的最大值
  • 两者一正一负,取他们的和

场景二:父子节点的元素穿透

父节点没设置margin-top,子节点设置了margin-top,则子节点的margin-top则会穿透到父节点产生间距,当然这种场景一般我们直观感觉不到,确实存在这种场景

场景二:空元素上下边距重叠

一个空元素的存在,且设置了上下边距,一般我们认为就是一个占高的元素,通常我们会直接设置height,如果同时设置了margin-top、margin-bottom,则上下边距会重叠选择最大值,合并成他的占位高度,这个见到的非常少了

ps:我们正常编写为了避免出现此类问题,可以尽量使用 BFC 场景,例如:我们使用flex布局,子元素就不会出现重叠了

相关推荐
沙振宇3 分钟前
【Web】使用Vue3+PlayCanvas开发3D游戏(六)模拟自驾场景SR+3D可视化
前端·游戏·3d·vue3·playcanvas
吴所畏惧9 分钟前
前端打包cdn或者dll打包方式
前端
小鲤鱼ya13 分钟前
vue3 + ts + uni-app 移动端封装图片上传添加水印
前端·typescript·uni-app·vue3
霍理迪14 分钟前
Vue—条件渲染与循环渲染
前端·javascript·vue.js
xixixin_18 分钟前
【CSS】字体大小不一致?px与vw渲染差异的底层原理与解决方案
前端·css
小J听不清23 分钟前
CSS 内边距(padding)全解析:取值规则 + 表格实战
前端·javascript·css·html·css3
zhangjikuan8925 分钟前
在 ArkTS 中,Promise 的使用比 TypeScript 更严格(必须显式指定泛型类型)
前端·javascript·typescript
桐溪漂流25 分钟前
Uni-app H5 环境下 ResizeObserver 监听 mp-html 动态高度
前端·uni-app·html
Highcharts.js26 分钟前
React 如何实现大数据量图表(性能优化指南)
前端·javascript·react.js·信息可视化·集成·highcharts
奔跑的呱呱牛27 分钟前
如何设计一个可扩展的地图前端架构?从0到1的工程实践(OpenLayers)
前端·架构·openlayers