首页 > 其他 > 详细

解决 外边距折叠问题

时间:2020-04-08 12:25:01      阅读:47      评论:0      收藏:0      [点我收藏+]

当两个元素 垂直相邻 时,如果两个元素分别向同一方向设置了各自的外边距,那么会产生合并,取其中最大正值。
技术分享图片
技术分享图片

如果其中一个元素是负的呢?
答案: 正值 - 负值 得 正值
技术分享图片

如果两个元素都是负值呢?
答案:负值 - 负值 得 负值
技术分享图片

总结:
1.如果存在负值,会是减法
2.如果是正值,则直接取大值

博主建议:上面的了解一下就行,知道这么一个问题,然后知道怎么解决就行。

解决办法: 只给一个元素设置外边距就好了,或者触发 BFC 但不推荐。
为什么触发 BFC 能解决外边距折叠?
答:因为外边距折叠只会发生在属于同一BFC的块级元素之间。

如果你不知道什么是 BFC, 可以看这篇来自 MDN 的文章
https://developer.mozilla.org/zh-CN/docs/Web/Guide/CSS/Block_formatting_context

还有参考文献:
https://developer.mozilla.org/zh-CN/docs/Web/CSS/CSS_Box_Model/Mastering_margin_collapsing
https://drafts.csswg.org/css-display/#valdef-display-flow-root

解决 外边距折叠问题

原文:https://www.cnblogs.com/xiaolantian/p/12658885.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!