[总结]BFC

BFC定义

BFC 的全称是 Block Formatting Context,块级格式化上下文。是用于布局块级盒子的独立渲染区域,且这个区域与外部不相关.

将处于BFC区域内和区域外的元素进行互相隔离。

简单的来说:BFC就是css的一个布局概念,是一个独立的区域(容器)

 

文档流分类

文档流分为:浮动流、定位流、普通的标准流,而普通标准流其实就是BFC中的FC.

FC:formatting context的英文缩写,翻译过来就是格式化上下文,它是页面中的一块渲染区域,有一套渲染规则,决定了其子元素如何布局,以及与元素之间的关系和作用。

常见的FC:BFC(块级格式化上下文)、IFC(行级格式上下文)、GFC(网络布局格式上下文)、和FFC(自适应格式上下文)。

触发BFC的条件

满足下列条件之一就可以触发BFC

  • 根元素,即html元素;

  • position 值为 absolutefixed

  • float 值不为 none

  • overflow 值不为 visible

  • display的值为inline-blockflextable-cell

BFC的应用场景

1.场景一:防止两个相邻块级元素的上下 margin 发生重叠 (上下margin合并问题)

属于同一 BFC 的, 两个相邻块级子元素的上下 margin 会重叠,如果想让它们不重叠,可通过让这两个相邻块级子元素分属于不同的BFC。

以下示例代码中的两个盒子的上下外边距会重合(即它们都设置了10px的外边距,我们期望它们之间的间距是 20px,但实际效果却只有 10px):

 

<style>
  .box1 {
    width: 200px;
    height: 100px;
    background-color: red;
    margin-bottom: 10px; /* 下外边距为 10px */
  }
​
  .box2 {
    width: 200px;
    height: 100px;
    background-color: green;
    margin-top: 10px;  /* 上外边距为 10px */
  }
</style>
​
<div class="box1"></div>
<div class="box2"></div>

下面我们让其中一个盒子触发BFC,从而达到间隔 20px 的期望效果:

 

.box2 {
  width: 200px;
  height: 100px;
  background-color: green;
  margin-top: 10px;
  display: inline-block; /* 通过设置 display 为 inline-block 可以触发 BFC */
}

2.场景二:清除浮动

以下示例代码中, 容器元素 box1 没有设置高度:

<style>
  .box1 {
    width: 200px;
    border: solid 2px pink;
    background-color: red;
  }
  .box2 {
    float: left;
    background-color: green;
  }
</style>
​
<div class="box1">
  <div class="box2">1</div>
  <div class="box2">2</div>
  <div class="box2">3</div>
</div>

而通过为 box1 添加 BFC 触发条件,可以让它的高度变回正常状态:

.box1 {
  width: 200px;
  background-color: red;
  overflow: hidden;
}

3.场景三:实现自适应布局, 防止元素被浮动元素覆盖(左边固定, 右边自适应)

以下示例中,box2 会被设置了浮动的 box1 覆盖:

 

<style>
  .box1 {
    float: left;
    width: 300px;
    background-color: red;
    height: 400px;
  }
​
  .box2 {
    background-color: blue;
    height: 600px;
  }
</style>
​
<div class="box1"></div>
<div class="box2"></div>

要避免这种覆盖行为,可以让 box2 触发 BFC, 实现布局效果, 左边固定右边自适应:

.box2 {
  background-color: blue;
  height: 600px;
  overflow: hidden; /* 将 overflow 设置为非 visible 值可触发 BFC */
}

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

端端1023

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值