bfc块级格式化上下文

BFC是什么,为什么需要它,它具体做什么,请用代码举例

BFC (块级格式化上下文) 是 CSS 布局的一种概念,用于描述一个独立的布局环境,它影响了其中的元素的布局、定位和浮动等行为。BFC 是浏览器渲染页面时的一种隔离机制,它的创建和应用有助于解决一些常见的布局问题。

为什么需要 BFC?
BFC 的主要作用是提供一个自包含的布局环境,可以解决一些常见的布局问题,例如:浮动元素引起的父元素塌陷、清除浮动、阻止 margin 重叠等。

BFC 具体做什么?
在 BFC 中,块级盒子按照特定的规则进行布局,这些规则包括:

  1. 每个元素的左外边距都会与其包含块的左边界相接触(从左到右的格式化上下文)。
  2. 块级框在垂直方向上一个接一个地排列。
  3. 相邻的块级框垂直方向的 margin 会发生重叠。
  4. BFC 具有边界区域,里面的所有元素的上下边距会发生重叠,但是与外部元素不重叠。
  5. BFC 可以包含浮动的元素,所以不会发生父元素因浮动元素而崩塌的情况。
    等等。

BFC的形成条件,请分别举例说明

BFC(块级格式化上下文)是一个独立的渲染区域,具有一定的布局规则,它影响其中的元素的布局、定位和浮动等行为。BFC 的形成条件包括以下几种情况:

  1. 浮动元素:元素的 float 属性不为 none。
  2. 绝对定位元素:元素的 position 属性为 absolute 或 fixed。
  3. inline-block 元素:元素的 display 属性为 inline-block。
  4. overflow 不为 visible 的块级元素:元素的 overflow 属性值不为 visible。

下面分别举例说明这些情况下 BFC 的形成条件:

  1. 浮动元素:当一个元素设置了 float 属性时,会创建一个 BFC。浮动元素不会影响外部元素的布局,而是脱离文档流,相对于父级容器定位,其他内容会围绕着浮动元素进行排列。
<style>
.container {
  border: 1px solid black;
}

.float-element {
  float: left;
  width: 100px;
  height: 100px;
  background-color: red;
}
</style>

<div class="container">
  <div class="float-element"></div>
  <div>这是一个普通元素,会围绕着浮动元素排列。</div>
</div>
  1. 绝对定位元素:当一个元素设置了 position 为 absolute 或 fixed 时,它会脱离文档流并创建一个 BFC。绝对定位元素的定位是相对于包含块(通常是最近的已定位祖先元素)进行的。
<style>
.container {
  position: relative;
  border: 1px solid black;
}

.absolute-element {
  position: absolute;
  top: 10px;
  left: 10px;
  background-color: blue;
}
</style>

<div class="container">
  <div class="absolute-element"></div>
  <div>这是一个绝对定位元素,相对于包含块进行定位。</div>
</div>
  1. inline-block 元素:当一个元素的 display 属性设置为 inline-block 时,它会创建一个 BFC。行内块元素会按照块级元素的方式进行布局,不会受到外部元素的影响。
<style>
.container {
  border: 1px solid black;
}

.inline-block-element {
  display: inline-block;
  width: 100px;
  height: 100px;
  background-color: green;
}
</style>

<div class="container">
  <div class="inline-block-element"></div>
  <div>这是一个行内块元素,不会受到外部元素的影响。</div>
</div>

bfc概念

BFC 指的是 Block Formatting Context,是 CSS 中的一个概念。它是页面中的一块渲染区域,规定了内部块盒子如何布局,并且与外部元素相互隔离。BFC 的形成主要有以下几种情况:

  1. 根元素或包含根元素的元素。
  2. 浮动元素(float 不为 none)。
  3. 绝对定位元素(position 为 absolute 或 fixed)。
  4. 行内块元素(display 为 inline-block)。
  5. 表格单元格(display 为 table-cell)。
  6. overflow 值不为 visible 的块元素。

BFC 在页面布局中扮演着重要的角色,可以解决一些常见的布局问题,例如浮动元素造成的父元素塌陷等。
一个BFC区域只包含其子元素,不包括其子元素的子元素。
并不是所有的元素都能成为一块BFC区域,只有当这个元素满足条件的时候才会成为一块BFC区域。
不同的BFC区域之间是相互独立的,互不影响的。利用这个特性我们可以让不同BFC区域之间的布局不产生影响。

高度塌陷

.father{
    width:300px;
    height: 300px;
    background-color: red;
    overflow: hidden;
}
.son{
    width: 100px;
    height: 100px;
    background-color: yellow;
    margin-top:50px;
}
<div class="father">
    <div class="son"></div>
</div>

清除浮动

.father{
    width:300px;
    background-color: red;
    overflow: hidden;
}
.son{
    width: 100px;
    height: 30px;
    background-color: yellow;
    border: 1px solid lime;
    float: left;
}
<div class="father">
    <div class="son"></div>
    <div class="son"></div>
    <div class="son"></div>
    <div class="son"></div>
    <div class="son"></div>
    <div class="son"></div>
    <div class="son"></div>
    <div class="son"></div>
</div>

margin重叠1

#c1 {
    width: 100px;
    height: 100px;
    background-color: red;
    float: left;
    margin: 10px;
}

#c2 {
    margin: 10px;
    width: 120px;
    height: 120px;
    background-color: blue;
    float: left;
}
<div id="c1"></div>
<div id="c2"></div>

margin重叠2

#c1 {
    width: 100px;
    height: 100px;
    background-color: red;
    float: left;
    margin: 10px;
}
#c2 {
    width: 120px;
    height: 120px;
    background-color: blue;
    margin: 10px;
}
#wrap{
    overflow: hidden;
}
<div id="c1"></div>
<div id="wrap">
    <div id="c2"></div>
</div>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值