什么是块级格式化上下文(BFC),如何工作?

简介: 什么是块级格式化上下文(BFC),如何工作?

块级格式化上下文(BFC)是一个独立的渲染区域,内部的元素按照一定的规则进行布局和渲染。

BFC的工作原理如下:

  1. 创建BFC:当元素满足一定条件时,将其创建为一个BFC。常见的条件包括:根元素、浮动元素、绝对定位元素、inline-block元素、overflow不为visible的元素等。
  2. 渲染规则:BFC内部的元素采用垂直方向的布局,每个元素在垂直方向上一个接一个地放置。元素在水平方向上尽可能地占据整个容器的宽度,除非有浮动元素或者绝对定位元素的影响。
  3. 边距折叠:相邻的两个块级元素在竖直方向上的外边距会发生折叠(合并),但是在不同的BFC之间的元素不会发生折叠。
  4. 清除浮动:BFC可以包裹浮动元素,使得父元素的高度被撑开,避免父元素塌陷。

下面是一个示例代码,展示如何创建一个BFC:

<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中。

相关文章
|
3月前
|
Perl
awk复杂用法多模式和多动作块
awk复杂用法多模式和多动作块
20 2
|
4月前
|
前端开发 容器
理解BFC(块级格式化上下文)及其应用
理解BFC(块级格式化上下文)及其应用
|
7月前
|
前端开发 容器
前端CSS理解 —— BFC(块级格式化上下文)
前端CSS理解 —— BFC(块级格式化上下文)
36 0
|
8月前
|
安全
RxSwift特征序列Driver的使用,以及共享附加作用与非共享附加作用的区别?
RxSwift特征序列Driver的使用,以及共享附加作用与非共享附加作用的区别?
134 0
|
9月前
|
Web App开发 机器人 数据安全/隐私保护
将上下文长度扩展到256k,无限上下文版本的LongLLaMA来了?
将上下文长度扩展到256k,无限上下文版本的LongLLaMA来了?
135 0
|
IDE Java 开发工具
Python语言应该加上块标识(开始、结束)的特性
Python语言应该加上块标识(开始、结束)的特性
78 0
西门子S7-1200的运动控制功能、系统使能指令块、错误确认指令块、回参考点或设置参考点指令块的参数含义
今天我们来介绍西门子S7-1200的运动控制功能。西门子S7-1200的运动控制指令是通过使用相关工艺数据块和CPU的专用脉冲串输出来控制轴的运动。
西门子S7-1200的运动控制功能、系统使能指令块、错误确认指令块、回参考点或设置参考点指令块的参数含义
西门子S7-1200的程序结构,块,组织块OB,功能块FB,功能FC
在S7-1200的编程中采用了块的概念,即将程序分解为独立的自成体系的各个部件,块类似于子程序的功能,但类型更多,功能更强大。在工业控制中,程序往往是非常庞大和复杂的,采用块的概念,便于大规模的程序设计和理解,也可以设计标准化的块程序进行重复调用。在S7-1200中支持以下类型的代码块,使用他们可以创建有效的用户程序结构,组织块OB、功能FC、功能块FB、数据块DB。
西门子S7-1200的程序结构,块,组织块OB,功能块FB,功能FC
|
前端开发
【CSS】有意思的BFC:Block Formatting Context(块格式化上下文)!🤡
前言 大家好,我是HoMeTown,今天想聊一聊CSS中的BFC,很多朋友应该都听过这个名词,搞懂BFC可以让我们理解CSS中一些很诡异的地方,话不多说,直奔主题!
37 0