美文网首页
边距合并和BFC

边距合并和BFC

作者: NSO | 来源:发表于2016-07-23 22:46 被阅读11次

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


什么叫边距合并

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

  • 当子元素和父元素垂直之间没有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

相关文章

  • 边距合并和BFC

    首先明确边距合并是个什么问题。举例说明: 总结边距合并的三种情况(上图都已经有体现了): 当子元素和父元素垂直之间...

  • 边距合并、BFC

    1.在什么场景下会出现外边距合并?如何合并?如何不让相邻元素外边距合并?给个父子外边距合并的范例。 外边距合并指的...

  • 外边距合并和BFC那点事

    边距合并 合并条件: 在常规文档流(非float和绝对定位)的块级盒子,处于同一个BFC当中。没有线盒,没有空隙(...

  • BFC(块级格式化上下文)

    边距塌陷的解决方法-触发BFC给父元素添加overflow:hidden; BFC(块级格式化上下文)a.BFC有...

  • BFC与边距重叠

    一、 什么是BFC 块级格式化上下文(Block Formatting Context),也就是常说的BFC,它是...

  • BFC与边距合并

    什么是BFC 对于浮动元素和绝对定位元素,非块级盒子的块级容器(inline-block,table-cells,...

  • 定位BFC边距合并

    1、有几种定位方式,分别是如何实现定位的,参考点是什么,使用场景是什么? 绝对定位:absolute(相对于 st...

  • BFC和边距合并

    BFC BFC 全称 Block Formatting Context每个渲染区域用formatting cont...

  • BFC(边距重叠解决方案)

    BFC基本概念:块级格式化上下文。BFC的原理: 在BFC这个元素的垂直方向的边距发生重叠; BFC的区域不会与浮...

  • 我的布局实例

    下拉菜单 demo BFC 两栏布局 demo 负边距 两栏布局 demo 负边距 等边布局 demo 圣杯三栏布...

网友评论

      本文标题:边距合并和BFC

      本文链接:https://www.haomeiwen.com/subject/pwpwjttx.html