CSS-BFC(块级格式化上下文)

一、BFC 的本质理解(快递仓库比喻)

想象一个快递分拣仓库(BFC容器),这个仓库有特殊的规则:

  1. 仓库内的包裹(内部元素)摆放不影响其他仓库
  2. 包裹必须整齐堆叠,不能越界
  3. 不同仓库之间的包裹互不干扰

BFC(Block Formatting Context,块级格式化上下文)就是这样一个独立的渲染区域,内部的布局规则与外部隔离。

二、触发 BFC 的 7 种条件

触发方式代码示例常见使用场景
根元素<html>默认触发
浮动元素float: left/right图文混排
绝对定位元素position: absolute/fixed弹窗、悬浮元素
display: inline-blockdisplay: inline-block行内块布局
overflow 非 visibleoverflow: hidden/auto清除浮动
弹性盒子display: flex现代布局方案
网格容器display: grid网格布局

三、BFC 的核心特点

  1. 独立王国:内部元素布局不影响外部
  2. 垂直排列:块级盒子从上到下排列(默认)
  3. 边界约束:子元素不会超出容器边界
  4. 间距计算:包含内部所有元素的外边距

四、BFC 的核心作用

1. 阻止外边距合并(Margin Collapse)

问题现象

<div class="box1">Box1</div>
<div class="box2">Box2</div><style>
.box1 { margin-bottom: 20px; }
.box2 { margin-top: 30px; }
/* 实际间距是30px,不是50px */
</style>

BFC解决方案

<div class="bfc-container"><div class="box1">Box1</div>
</div>
<div class="box2">Box2</div><style>
.bfc-container { overflow: hidden; } /* 触发BFC */
</style>

2. 清除浮动(Contain Floats)

问题现象

<div class="parent"><div class="float-child"></div>
</div>
<!-- parent高度塌陷 -->

BFC解决方案

.parent {overflow: auto; /* 触发BFC */
}

3. 阻止元素被浮动覆盖

问题现象

<div class="float-left"></div>
<div class="normal-box"></div> <!-- 被浮动元素覆盖 -->

BFC解决方案

.normal-box {overflow: hidden; /* 触发BFC *//* 现在会与浮动元素并排显示 */
}

4. 自适应两栏布局

<div class="left"></div>
<div class="right"></div><style>
.left {float: left;width: 200px;
}
.right {overflow: hidden; /* 触发BFC *//* 自动填满剩余宽度 */
}
</style>

5. 隔离布局环境

<div class="container"><div class="bfc-box">内部元素</div><div class="normal-box">外部元素</div>
</div><style>
.bfc-box {overflow: hidden; /* 触发BFC */margin-top: 50px; /* 不会影响外部元素 */
}
</style>

五、BFC 的经典使用场景

1. 防止浮动导致父元素高度塌陷

.parent {overflow: hidden; /* 触发BFC */
}

2. 实现自适应两栏/三栏布局

.main {overflow: hidden; /* 自动计算剩余宽度 */
}
.aside {float: left;width: 200px;
}

3. 解决垂直外边距合并问题

<div class="section"><div class="bfc-container"><p>内容</p></div>
</div><style>
.bfc-container {overflow: hidden; /* 阻止外边距穿透 */
}
</style>

4. 避免文字环绕

.text-wrapper {overflow: hidden; /* 创建独立文本区域 */
}

5. 隔离第三方组件样式

.widget {overflow: hidden; /* 防止组件内部样式影响外部 */
}

6. 防止Sticky定位失效

.container {overflow: hidden; /* 创建新的定位上下文 */
}
.sticky-element {position: sticky;top: 20px;
}

六、BFC 使用注意事项

  1. 避免滥用overflow: hidden 可能导致内容截断
  2. 性能影响:某些BFC触发方式会创建新的层叠上下文
  3. 选择最优解:优先使用现代布局方案(Flex/Grid)
  4. 兼容性检查:旧版IE对某些触发方式支持有限

七、BFC 与 其他格式化上下文

类型触发方式布局方向
BFC请看前文块级垂直排列
IFCdisplay: inline行内水平排列
FFCdisplay: flex弹性盒排列
GFCdisplay: grid网格布局

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/42958.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

最大数字(java)(DFS实现)

1.最大数字 - 蓝桥云课 因为N最大是10 的17次方&#xff0c; 所以可以利用字符串来处理输入的数字的每一位 并且是从高到低依次处理的 然后通过函数charAt(i)来获取第i位的字符 再减去‘0’就可以将字符转化为整型了 假设每一位数字都是x 然后通过两种操作 加或者减来操…

04 单目标定实战示例

看文本文,您将获得以下技能: 1:使用opencv进行相机单目标定实战 2:标定结果参数含义和数值分析 3:Python绘制各标定板姿态,查看图像采集多样性 4:如果相机画幅旋转90,标定输入参数该如何设置? 5:图像尺寸缩放,标定结果输出有何影响? 6:单目标定结果应用类别…

手机销售终端MPR+LTC项目项目总体方案P183(183页PPT)(文末有下载方式)

资料解读&#xff1a;手机销售终端 MPRLTC 项目项目总体方案 详细资料请看本解读文章的最后内容。在当今竞争激烈的市场环境下&#xff0c;企业的销售模式和流程对于其发展起着至关重要的作用。华为终端正处于销售模式转型的关键时期&#xff0c;波士顿 - 华为销售终端 MPRLTC …

如何在 vue 渲染百万行数据,vxe-table 渲染百万行数据性能对比,超大量百万级表格渲染

vxe-table 渲染百万行数据性能对比&#xff0c;超大量百万级表格渲染&#xff1b;如何在 vue 渲染百万行数据&#xff1b;当在开发项目时&#xff0c;遇到需要流畅支持百万级数据的表格时&#xff0c; vxe-table 就可以非常合适了&#xff0c;不仅支持强大的功能&#xff0c;虚…

ubuntu24 部署vnc server 使用VNC Viewer连接

前提条件 已创建一台Ubuntu 24.04(20.22通用)操作系统的云服务器&#xff0c;并且为云服务器绑定弹性公网IP&#xff0c;确保可以连接互联网。 已在本地PC安装VNC Viewer客户端。 操作步骤 服务器内安装vnc server以及桌面环境 apt update sudo apt install xfce4 xfce4-…

【数据结构】栈 与【LeetCode】20.有效的括号详解

目录 一、栈1、栈的概念及结构2、栈的实现3、初始化栈和销毁栈4、打印栈的数据5、入栈操作---栈顶6、出栈---栈顶6.1栈是否为空6.2出栈---栈顶 7、取栈顶元素8、获取栈中有效的元素个数 二、栈的相关练习1、练习2、AC代码 个人主页&#xff0c;点这里~ 数据结构专栏&#xff0c…

06-SpringBoot3入门-常见注解(简介)

1、Controller ResponseBody Controller是Spring MVC 中的注解&#xff0c;负责处理 HTTP 请求。 ResponseBody是Spring MVC 中的注解&#xff0c;用于直接将方法的返回值作为 HTTP 响应体。 2、RestController RestController Controller ResponseBody 3、RequestMappin…

工作记录 2017-03-10

工作记录 2017-03-10 序号 工作 相关人员 1 修改邮件上的问题。 更新RD服务器。 郝 更新的问题 1、修改了payment detail和patient insurance的health plan的输入方式。 2、new payment detail时&#xff0c;增加了allowable的处理。 3、选择payer的窗体&#xff0c;增…

MySQL数据库和表的操作

#使用数据库 use 数据库名; # 查询当前数据库是哪个数据库 select database(); 查看数据库版本 SELECT VERSION(); 查看当前用户 SELECT USER(); 查看所有用户() SELECT User,Host,Password FROM mysql.user;数据库 MySQL自带数据库&#xff1a; Information_schema: 主要存储…

lxd-dashboard 图形管理LXD/LXC

前言 LXD-WEBGUI是一个完全用AngularJS编写的Web应用程序,无需应用服务器、数据库或其他后端服务支持。只需要简单地托管静态HTML和JavaScript文件,就能立即投入使用。这个项目目前处于测试阶段,提供了直观的用户界面,帮助用户便捷地管理和控制LXD实例。 安装lxd-dashboa…

[GESP202503 C++一级题解]:B4257:图书馆里的老鼠

[GESP202503 C++一级题解]:B4257:图书馆里的老鼠 题目描述 图书馆里有 n n n 本书,不幸的是,还混入了一只老鼠,老鼠每 x x x 小时能啃光一本书,假设老鼠在啃光一本书之前,不会啃另一本。请问 y y y 小时后图书馆里还剩下多少本完整的书。 输入格式 三行,第一行一…

从零构建大语言模型全栈开发指南:第二部分:模型架构设计与实现-2.2.2文本生成逻辑:Top-k采样与温度控制

👉 点击关注不迷路 👉 点击关注不迷路 👉 点击关注不迷路 文章大纲 2.2.2 文本生成逻辑:Top-k采样与温度控制1. 文本生成的核心挑战与数学框架1.1 自回归生成的基本流程2. `Top-k`采样原理与工程实现2.1 数学定义与算法流程2.2 PyTorch实现优化3. 温度控制的数学本质与参…

Unity中实现UI的质感和圆角

质感思路有两种&#xff1a; 一种是玻璃质感的做法&#xff0c;抓取UI后面的图像做模糊&#xff08;build是GrabPass&#xff0c;urp抓图像我有写过在往期文章&#xff09;&#xff0c;这个方式网络上有很多就不写了&#xff1b; 另外一种是使用CubeMap的方式去模拟质感&…

[异步监听事件、异步绑定属性]通过vue的this.$refs.组件.$props和.$on实现异步绑定组件属性和事件监听

child.vue <template><div><el-button type"primary" click.stop"$emit(get, data)">点击传参</el-button></div> </template> <script> export default { name: "child", props: ["data"…

第六届 蓝桥杯 嵌入式 省赛

参考 第六届蓝桥杯嵌入式省赛程序设计题解析&#xff08;基于HAL库&#xff09;_蓝桥杯嵌入式第六届真题-CSDN博客 一、分析功能 RTC 定时 1&#xff09;时间初始化 2&#xff09;定时上报电压时间 ADC测量 采集电位器的输出电压信号。 串行功能 1&#xff09;传送要设置…

为什么要将项目部署到外部tomcat

一、是什么 指将你的Java Web应用程序&#xff08;如WAR包&#xff09;安装并运行在一个独立安装的、位于项目外部的Tomcat服务器上&#xff0c;而不是使用内嵌的或开发环境自带的服务器。 外部Tomcat 指独立安装的Tomcat服务器&#xff08;如从Apache官网下载的Tomcat&#…

企业级全栈开发终极指南:Spring Boot+Vue3+Kubernetes实战,从0到上线高并发系统

简介 本文以电商系统为例,完整呈现从需求分析到上线运维的企业级开发全流程。包含12个关键步骤、30+代码示例、5个架构设计图,以及完整的Docker/Kubernetes部署方案。所有代码均符合企业级规范,可直接用于生产环境。 企业级开发的终极挑战 行业痛点: 90%的开发者在企业级…

蓝桥杯嵌入式赛道复习笔记8(eeprom读写)

原理学习 自己看一下江科大的存储器的读取&#xff0c;原理是一样的。只是使用了IIC原理是不变的 代码 cubeMX的配置 代码 eeprom层代码的书写 #include "eeprom_display.h" uint8_t data; uint8_t eeprom_read(uint8_t addr){I2CStart();I2CSendByte(0xa0);I2…

IP数据报报文格式

一 概述 IP数据报由两部分组成&#xff1a;首部数据部分。首部的前一部分是固定长度&#xff0c;一共20字节大小&#xff0c;是所有IP数据报文必须具有的&#xff1b;固定部分后面是一些可选字段&#xff0c;其长度是可变的。 二 首部固定部分各字段意义 &#xff08;1&…

高光谱工业相机+LED光源系统助力材料分类和异物检测、实现高速在线检测

检测光源包括可见光&#xff0c;如红光、蓝光和绿光以及其他波长的光&#xff0c;如紫外和红外波长&#xff0c;可以选择与检测对象物相应的波长。但由于能够照射的波长较窄&#xff0c;例如受到同色异物混入或多个素材的材质分类等&#xff0c;可能需要使用可照射多种波长的光…