普通流布局
在讲BFC之前,我们先了解一下CSS中最常见的普通流布局
元素在页面上自上而下、从左往右排列,块级元素独自占据一整行,而行内元素在水平方向上一个接一个排列,直到排满了才换行。元素默认情况下都是属于普通流的。
什么是BFC
块级格式化上下文(Block Formatting Context,简称BFC)也是属于普通流的,它是一个独立的渲染区域,在这个区域里面的元素和外面的元素互不干扰。
如何触发BFC
常见的方法有:
- 根元素(
<html>
) - 浮动元素(元素的
float
不是none
) - 绝对定位元素(元素的
position
为absolute
或fixed
) - display为
inline-block
、table-cell
、table-caption
、flex
、inline-flex
、grid
、inline-grid
等值的元素 overflow
不是visible
的元素
当然,还有一些其他的方法,常用的有display: flow-root;
,overflow: auto;
BFC的特性
- BFC是一个独立的区域,其内部元素和外部元素互不干扰。
- BFC的区域不会与float box重叠。
- 计算BFC的高度时,浮动元素也参与计算。
BFC的应用
清除浮动
我们来看如下代码:
html
<div class="container">
<div class="image"></div>
<div class="content">
"行李箱拖过几道车辙,是归人好似过路客。"
</div>
</div>
<style>
.container{
background-color: aqua;
}
.image{
width: 100px;
height: 100px;
background-color: pink;
float: left;
}
.content{
width: 200px;
}
</style>
效果是这样的:
而实际上我们想要的效果应该是这样:
那么为什么会出现上面那种效果呢?是这样的,.image
浮动后,父容器不会将其高度计算在内,父容器的高度仅仅由另一个非浮动元素撑开,所以就是上面那种效果。那么怎么达到我们想要的效果呢?只需要让父容器将浮动的子容器的高度计算在内就行了,即清除浮动。而BFC就有这个作用。
css
display: flow-root; // 在父容器中加上这条属性
当我们在父容器中加上这条属性之后,就会触发BFC,将里面浮动元素的高度计算在内,效果如下:
我们会发现,好像和我们想要的效果还是有点差距,这就涉及到BFC的另一个功能特性了。
阻止元素被浮动元素覆盖
上述代码中,我们.content
元素加了200px的宽度,但实际上,我们可以看到,.content
并没有这么宽,为什么呢?这是因为浮动元素将该元素的覆盖了一些。
css
display: flow-root; // 给被覆盖的元素添加该属性
具有BFC的元素的区域不会和浮动元素重叠,所以我们只需要让.content
成为BFC就好了,效果如下:
避免外边距重叠
html
<div class="itemOne"></div>
<div class="itemTwo"></div>
<style>
.itemOne{
width: 100px;
height: 100px;
background-color: pink;
margin: 10px;
}
.itemTwo{
width: 100px;
height: 100px;
background-color: aqua;
margin: 10px;
}
</style>
我们给这两个容器都设置了外边距10px,理论上,上面容器和下面容器之间的边距应该有20px,我们来看效果图:
我们会发现这两容器之间只有10px的边距,怎么解决呢?
html
<div class="itemOne"></div>
<div style="display: flow-root;"></div>
<div class="itemTwo"></div>
只需要在这两个容器之间放一个空的BFC,由于BFC和外部的元素互不干扰,所以BFC上面的容器的外边距自然就不会和BFC重叠,下面也是同理,这样就解决了外边距重叠的问题,效果如下: