CSS中的BFC 与 margin塌陷

一、CSS中的BFC

  BFC :  直译为“块级格式化上下文”。他是一个独立的渲染区域,只有Block-level Box参与,它规定了内部的Block-level Box如何布局,并且与这个区域外部毫不相干。

 

  BFC布局规则:

    1.内部的Box会在垂直方向,一个接一个地放置。

    2.BFC的区域不会与float box重叠

    3.内部的Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生重叠,取这两个Box的margin中的较大值。

    4.计算BFC的高度时,浮动元素也参与计算。(清除浮动 haslayout)

    5.BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。

 

  BFC什么时候出现(哪些元素会生成BFC):

    根元素

    float属性不为none

    position为absolute或者fixed

    overflow不为visible

    display为inline-block,table-cell,table-caption,flex,inline-flex

 

二、margni塌陷

  在文档流中,父元素的高度默认是被子元素撑开的
  也就是说 子元素有多高,父元素就有多高
  但是当子元素设置浮动之后,子元素会完全脱离文档流
  此时将会导致子元素无法撑开父元素的高度,导致父元素高度塌陷

 

 

参考博客:

  https://www.cnblogs.com/xiaohaodeboke/p/11744122.html                 

  https://blog.csdn.net/sinat_36422236/article/details/88763187

原文地址:https://www.cnblogs.com/xiaohaodeboke/p/12500169.html