标签:line mat 元素 宽度 http 相互 定位 塌陷 存在
首先按照常规解释一下名词,BFC(Block formatting context)直译为"块级格式化上下文"。一个独立的渲染区域,只有Block-level box参与, 它规定了内部的Block-level Box如何布局和渲染,并且有一套自己的渲染规则,它决定了其子元素将如何定位,以及和其他元素的关系和相互作用,并且与这个区域外部毫不相干。
然后大脑出现三个???,那接着往下看,我们在清除浮动的时候一般利用三个方法,伪元素::after、空<div>盒子,还有给父元素添加overflow:hidden;第一个和第二好理解,就是在浮动元素后面清除浮动,那么第三个呢,我最开始在网上找到的答案是,设置了overflow属性,会重新计算盒子的高度和宽度 从而撑起了塌陷的盒子。直到开始接触BFC概念,第三种方法正是用到了BFC,接下进入正题。
通俗点理解,BFC就是一个隔离了的独立容器,容器里面的元素不会在布局上影响到外面的元素,并且 BFC 具有普通容器所没有的一些特性。
只要元素满足下面任一条件即可触发 BFC 特性:
BFC
内部的元素和外部的元素绝对不会互相影响,因此, 当BFC
外部存在浮动时,它不应该影响BFC
内部Box的布局,BFC
会通过变窄,而不与浮动有重叠。同样的,当BFC
内部有浮动时,为了不影响外部元素的布局,BFC
计算高度时会包括浮动的高度。避免margin重叠也是这样的一个道理。”
标签:line mat 元素 宽度 http 相互 定位 塌陷 存在
原文地址:https://www.cnblogs.com/justnotwo/p/8759197.html