了解margin重叠切页面入门更丝滑

当入门切页面时,我们常常会感觉页面好像和自己有点奇怪,但是好像又没啥问题,那么可能就是因为边距重叠问题,本文就将带你了解什么是边距重叠问题,学会怎么解决它

问题

相邻兄弟元素的外边距取最大值

一个常见的问题是相邻兄弟元素之间外边距的计算。当这些兄弟元素都设置了上下外边距时,它们之间的上下边距会取两者中的最大值。这可能导致意外的布局结果。

两个容器之间发生边距重叠的外边距取得是最大值50px,上面容器的margin-bottom:30px被下方容器的margin-bottom覆盖

父子元素的外边距重叠

另一方面,父子元素的外边距重叠问题也需要我们关注。当一个父元素设置了上下外边距,同时最上或最下的子元素也设置了外边距并发生重叠时,边距重叠现象会导致取其中最大的一个作为父容器的外边距。

上面实际还有间距不止20px


父容器设置的margin-top:20px,但是实际上效果为30px,因为子容器的margin-top更大作为父容器的margin-top

解决重叠问题

以上是针对特定问题的解决方案,但我们还可以通过一些通用的方法来解决外边距问题,提高前端开发的效率和灵活性。

  1. 使用 Border 代替 Margin: 在一些情况下,我们可以考虑将元素的边框设置为透明的 border,以替代外边距的使用。这可以确保相邻元素之间有足够的间隔,避免合并和重叠。

  2. 使用padding 代替 margin : ,在子元素和父容器之间需要间距的时候可以为父容器设置padding而不是margin从而避免了边距重叠问题

  3. 使用空白元素隔开: 在特殊情况下,插入空白元素一定要设置样式为overflow:hidden可以帮助我们在布局中创造额外的间距,从而解决外边距问题。这是一个简单而直接的解决方案,适用于某些特定场景的问题解决。

总结

问题:

  1. 两个相邻兄弟元素,上下之间各自都设置了间距,间距会取两者最大值
  2. 父容器中,最上/最下的子元素设置了上边距/下边距,也会发生边界重叠的现象,取两者最大值作为父容器的外边距

解决:

  1. 使用空白元素隔开,空白元素设置样式overflow:hidden
  2. 使用border代替父元素margin
  3. 使用padding代替子元素

本人还在学习中,水平有限,文章可能存在纰漏或错误,如有问题欢迎指正,感谢你阅读这篇文章,如果你觉得写得还行的话,不要忘记点赞、评论、收藏哦!祝事业有成,生活愉快!😘

相关推荐
IMPYLH4 分钟前
HTML 的 <abbr> 元素
前端·算法·html
李白的天不白26 分钟前
Tree-Shaking
前端
Csvn1 小时前
TypeScript:你以为安全的 `JSON.parse` 其实是颗雷 — 运行时类型安全实战
前端·javascript
橘子星1 小时前
深入理解线性数据结构:栈、队列与链表
前端·javascript
dadaobusi1 小时前
Linux内核完成大量内存/调度/时间子系统初始化的关键阶段
java·linux·前端
用户059540174461 小时前
Redis 缓存过期不一致踩坑实录:一个 bug 让我排查了 3 小时,最终用 Pytest 自动化堵上漏洞
前端·css
东风破_1 小时前
AJAX 异步请求:从回调地狱到 async/await,到底解决了什么?
前端
Larcher1 小时前
JS 数据类型的八重人格与内存真相
前端·javascript
星辰徐哥1 小时前
工具推荐:HTML5+AI开发必备的前端调试工具
前端·人工智能·html5
Full Stack Developme1 小时前
Linux Shell 教程概览
linux·前端·chrome