一、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