边距合并和BFC

首先明确边距合并是个什么问题。
举例说明:


什么叫边距合并

总结边距合并的三种情况(上图都已经有体现了):

  • 当子元素和父元素垂直之间没有padding、没有border也没有内容时就会发生外边距合并,总体外边距变为两个外边距中的较大者
  • 相邻兄弟元素的垂直上下之间也会出现外边距合并;
  • 一个元素内部没有内容、没有border、也没有padding会发生外边距合并;

题外话:为什么发生边距合并?

首先要明白html最初设计目的是和一个文本文档一样,默认也是大家在里面写文章放图片,那么自然要换行,所以这个margin就是控制行间距的。自然很多情况下要智能地边距合并才能符合使用者的本意。所以不要怪罪浏览器的解析方式。

不感兴趣的就只看这句话:边距合并是个排版问题。

好了,重点是怎么解决边距合并问题。
比较通用的方法是使用BFC。解释一下BFC是啥:
BFC是块级元素自身形成独立的上下文排版的方式,形成BFC后外部floating、clear这些排版就失效了,BFC内部自己形成一个内部空间
形成BFC的方式,为了防止误解直接给出MDN上的原文:

A block formatting context is created by one of the following:

  1. the root element or something that contains it
  2. floats (elements where float is not none)
  3. absolutely positioned elements (elements where position is absolute or fixed)
  4. inline-blocks (elements with display: inline-block)
  5. table cells (elements with display: table-cell, which is the default for HTML table cells)
  6. table captions (elements with display: table-caption, which is the default for HTML table captions)
  7. elements where overflow has a value other than visible
  8. flex boxes (elements with display: flex or inline-flex)

言归正传,我们解决边距合并问题不是用上面随便一条形成bfc就可以的。比如第1条,稍微思考一下就知道和解决我们的问题没关系。靠谱的是我们利用overflow设置一个属性(当然不能设置visiable上面已经说了)。
要说明三个重要问题:

  • 是父元素形成BFC才起作用,BFC外部和内部的排版时隔绝的,也就是我们要解决的排版问题
  • BFC不是专门用来解决边距合并的,自然会有副作用,还要自己思考最佳解决方案
  • 有的时候想一下到底是要margin还是padding
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,687评论 1 92
  • 一,浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动模型是一种可视化格式模型,浮动...
    DeeJay_Y阅读 4,404评论 0 4
  • 一、在什么场景下会出现外边距合并?如何合并?如何不让相邻元素外边距合并?给个父子外边距合并的范例 1、外边距和并的...
    鸿鹄飞天阅读 3,998评论 0 0
  • 1. 浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动元素特征:使元素脱离文档流,...
    萧雪圣阅读 1,417评论 0 1
  • 1. 在什么场景下会出现外边距合并?如何合并?如何不让相邻元素外边距合并?给个父子外边距合并的范例 外边距合并:外...
    进击的阿群阅读 4,533评论 1 2