块级格式化上下文(BFC)是一个独立的渲染区域,内部的元素按照一定的规则进行布局和渲染。
BFC的工作原理如下:
- 创建BFC:当元素满足一定条件时,将其创建为一个BFC。常见的条件包括:根元素、浮动元素、绝对定位元素、inline-block元素、overflow不为visible的元素等。
- 渲染规则:BFC内部的元素采用垂直方向的布局,每个元素在垂直方向上一个接一个地放置。元素在水平方向上尽可能地占据整个容器的宽度,除非有浮动元素或者绝对定位元素的影响。
- 边距折叠:相邻的两个块级元素在竖直方向上的外边距会发生折叠(合并),但是在不同的BFC之间的元素不会发生折叠。
- 清除浮动:BFC可以包裹浮动元素,使得父元素的高度被撑开,避免父元素塌陷。
下面是一个示例代码,展示如何创建一个BFC:
html
<style>
.container {
overflow: hidden; /* 创建BFC */
border: 1px solid red; /* 为了显示BFC区域边界 */
}
.float {
float: left;
width: 100px;
height: 100px;
background-color: blue;
}
.content {
background-color: yellow;
margin-left: 120px; /* BFC区域不受浮动元素的影响 */
}
</style>
<div class="container">
<div class="float"></div>
<div class="content">
This is the content.
</div>
</div>
在上面的代码中,container元素被设置为overflow: hidden,创建了一个BFC。float元素浮动在左侧,content元素在右侧,并不受float元素的影响,因为它们处于不同的BFC中。