块格式化上下文(Block Formatting Context,BFC) 是Web页面的可视化CSS渲染的一部分,是块盒子的布局过程发生的区域,也是浮动元素与其他元素交互的区域。
- 浮动元素:float 除 none 以外的值。
- 绝对定位元素:position (absolute、fixed)。
- display 为 inline-block、table-cells、flex。
- overflow 除了 visible 以外的值 (hidden、auto、scroll)。
BFC的作用:
让浮动内容和周围的内容等高
创建一个会包含这个浮动的BFC,通常的做法是设置父元素 overflow: auto
或者设置其他的非默认的 overflow: visible
的值。
<div class="box">
<div class="float">I am a floated box!</div>
<p>I am content inside the container.</p>
</div>
.box {
background-color: rgb(224, 206, 247);
border: 5px solid rebeccapurple;
overflow: auto;
}
.float {
float: left;
width: 200px;
height: 150px;
background-color: white;
border:1px solid black;
padding: 10px;
}
设置 overflow: auto
创建一个新的BFC来包含这个浮动。我们的 <div>
元素现在变成布局中的迷你布局。任何子元素都会被包含进去。
使用 overflow
来创建一个新的BFC,是因为 overflow
属性告诉浏览器你想要怎样处理溢出的内容。当你使用这个属性只是为了创建BFC的时候,你可能会发现一些不想要的问题,比如滚动条或者一些剪切的阴影,需要注意。另外,对于后续的开发,可能不是很清楚当时为什么使用overflow
。所以你最好添加一些注释来解释为什么这样做。
外边距塌陷
一个新的 display
属性的值,它可以创建无副作用的BFC。在父级块中使用 display: flow-root
可以创建新的BFC。
<div class="box">
<div class="float">I am a floated box!</div>
<p>I am content inside the container.</p>
</div>
.box {
background-color: rgb(224, 206, 247);
border: 5px solid rebeccapurple;
display: flow-root;
}
.float {
float: left;
width: 200px;
height: 150px;
background-color: white;
border:1px solid black;
padding: 10px;
}
原文链接:https://developer.mozilla.org/zh-CN/docs/Web/Guide/CSS/Block_formatting_context