【CSS】深入理解:BFC究竟是什么?

devtools/2024/9/18 12:27:41/ 标签: css, 前端

深入理解:BFC究竟是什么?

在我们了解BFC之前,我们先来看看什么是FC

1. FC的概念

FC全称 Formatting Context ,元素在标准流里面都属于一个FC

  • 块级元素的布局都属于Block Formatting Context,也就是BFC
    • block level box都是在BFC中布局的
  • 行内级元素的布局都属于Inline Formatting Context,IFC

2. BFC - Block Formatting Context

2.1 什么是BFC呢?怎么创造BFC?

常见的形成BFC的场景

  • 根元素(html,:root)
  • 浮动元素(float属性部位none)
  • 绝对定位元素(absolute或fixed)
  • 行内快元素(display为inline-block)
  • 表格单元格(元素的display为table-cell(默认))
  • 表格标题(display为table-caption)
  • 匿名表格单元格格式(元素的 display 为 table、table-row、 table-row-group、table-header-group、table-footer-group(分别是HTML table、 row、tbody、thead、tfoot 的默认属性)或 inline-table)
  • overflow属性值不是“visible”的元素
  • 弹性元素(flex布局)
  • 网格元素(gird布局)

2.2 BFC的作用

  1. 在BFC中,box会垂直方向上一个挨着一个排布
  2. 垂直方向的属性由magin决定
  3. 同一个BFC中,两个相邻的box上下之间的margin会折叠(规定)
  4. BFC中,每个元素的左侧边缘都是紧挨着包含块的左边缘

这就是浏览器如何排布我们的元素

2.3 利用BFC解决块级元素的margin上下折叠问题

css">.box {width: 100px;height: 100px;
}
.box1 {background-color: pink;margin-bottom: 50px;
}
.box2 {margin-top: 30px;background-color: purple;
}
<div class="box box1"></div>
<div class="box box2"></div>

在上述的代码中,box1和box2在同一个BFC中,(根元素html)会创建一个BFC,所以会折叠,两个box之间的距离为50px,我们可以利用BFC来解决这个问题

<div class="container"><div class="box box1"></div>
</div>
<div class="box box2"></div>

用一个div盒子来包裹box1

css">.container {overflow: auto;
}

当我们给box1的父盒子container设置overfolw的属性为auto时,此时container会开启一个BFC,此时,box1和box2并不是属于同一个BFC,所以不会出现margin上下折叠的问题

2.4 为什么BFC会解决浮动元素高度塌陷的问题呢?

网上有很多的说法,BFC可以解决浮动元素的塌陷问题,实现清除浮动的效果,那么请看这个案例

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>Document</title><style>css">ul,li {padding: 0;margin: 0;list-style: none;}.box ul {width: 330px;height: 150px;background-color: orange;overflow: hidden;}.box li {float: left;width: 100px;height: 100px;margin: 0 10px 10px 0;background-color: pink;}</style></head><body><div class="box"><ul><li>1</li><li>2</li><li>3</li><li>4</li><li>5</li></ul></div></body>
</html>

在这里插入图片描述

在这个案例中,我们给了ul 一个固定高度,也给ul设置了一个BFC,但并没有清除浮动

事实上,BFC解决高度塌陷的需要满足两个条件

  • 浮动元素的父元素开启BFC
  • 浮动元素的父元素高度是auto

当BFC的高度为auto时,将会计算父元素的高度(权威)

  1. 如果盒子中的子元素只有行内元素,直接计算顶部到底部的距离
  2. 如果有块级元素,计算块级元素的高度
  3. 如果有绝对定位元素,直接忽略其高度
  4. 如果有浮动元素,则会增加高度来包含这些浮动元素的下边缘

也就是我们可以得出一个重要结论,当元素开启新的BFC时,会主动将浮动元素给包括进去,并不是浮动元素向父元素汇报高度


http://www.ppmy.cn/devtools/12714.html

相关文章

偏微分方程算法之二阶双曲型方程隐式差分法

目录 一、研究目标 二、理论推导 三、算例实现 一、研究目标 上篇文章介绍了二阶双曲型方程显式差分格式&#xff0c;由于显格式稳定性要求高&#xff0c;使用范围受限。我们尝试对其进行差分隐格式推导。这里继续以非齐次二阶双曲型偏微分方程的初边值问题为研究对象&#…

上位机图像处理和嵌入式模块部署(树莓派4b实现xmlrpc通信)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 前面&#xff0c;我们也用纯API实现过上位机和开发板之间的通信。当时使用的方法&#xff0c;就是用windows自带的网络sdk和linux自带的api函数来完…

安装mmcv

一、先决条件 MMSegmentation 适用于 Linux、Windows 和 macOS。它需要 Python 3.6、CUDA 9.2 和 PyTorch 1.3。 Pytorch的配置教程可以参考我的另一篇文章。 Anaconda下载安装及配置pytorch环境_anaconda3 pytorch 安装-CSDN博客 二、最佳实践 步骤 0。使用 MIM 安装 MMC…

到底什么是爬虫

1. 引言 在数据驱动的世界里&#xff0c;网络爬虫&#xff08;Web Crawling&#xff09;技术扮演着获取和处理网上数据的关键角色。无论是为了数据分析、机器学习项目的数据集构建还是简单地监测网页变化&#xff0c;学习如何创建一个基本的网页爬虫可以大大提升你的工作效率和…

数据库——实 验 8 SQL 编程

1.T-SQL 语言简介 SQL Server 使用的语言称作 Transact-SQL, 它不仅包括基本 SQL 操作的内容&#xff0c;如 SQL 的数据查询功能和数据操作功能等&#xff0c;还有一般程序设计的能力。 2. 局部变量和全局变量的概念 1)局部变量 局部变量是一个能够拥有特定数据类型的对…

Llama 3问世:迄今为止的最强开源大语言模型

导语 最近Meta发布了其研发的第三代开源大语言模型Llama 3&#xff0c;并宣称Llama 3为迄今为止的最强开源大语言模型&#xff0c;本文对其进行简要学习记录。若想了解之前版本的Llama模型&#xff0c;可参考我之前写的论文笔记&#xff1a;Llama、Llama 2、CodeLlama。 要点…

vue3图片展示实战

首先得有一个vue3项目 教程&#xff1a; vue3项目搭建 我测试存在两种方式可以将本地图片进行展示到页面 public文件夹下可以直接导入src下的asset文件夹下的图片导入方式(图中是的原因是在默认配置中将src配置为了&#xff0c;也可以写全路径)网页图片不可导入&#xff0c;应…

已适配开源鸿蒙OpenHarmony 4.1,Purple Pi OH开发板与时俱进

2024年4月3日&#xff0c;备受瞩目的OpenHarmony 4.1 release版本正式发布。值得一提的是&#xff0c;触觉智能的Purple Pi OH已经成功适配了这一新版本&#xff0c;展现出强大的兼容性和前沿的技术实力。此次升级不仅彰显了OpenHarmony在开放能力和应用生态方面的持续进步&…

第十讲 - Java键盘输入

文章目录 第十讲 - Java键盘输入一&#xff0c;键盘录入涉及到的方法如下&#xff1a;1&#xff09;next&#xff08;&#xff09;、nextLine&#xff08;&#xff09;&#xff1a;代码示例&#xff1a;代码示例&#xff1a; 2&#xff09;nextInt&#xff08;&#xff09;&…

Unity学习记录使用frame debugger

首先在window->analyis里找到他 打开 然后点击 play&#xff0c;紧接着点击这里enable他 这时候界面就会被暂停 然后找一个看起来是绘制mesh的命令 可以看见这个mesh detail里还有更详细的信息 顶点数&#xff0c;面数&#xff0c;使用了什么shader&#xff0c;pass走的…

Go读取文件n行的思路之旅

【问题】最近想在一个10G的文件上读取最后100行数据&#xff0c;用了多种方式去实现&#xff0c;发现还是逆向读取比较香一点 【方法】分别尝试了两种方式&#xff1a;双端队列和逆读文件   在这里我就直接把结论放在文章前面 双端队列&#xff1a;适用于文件数据不大的情况…

Linux系统-服务器硬件及RAID配置

目录 一.服务器 1.服务器与普通计算机的区别 2.功能 3.分类&#xff08;按照产品形态分&#xff09; 4.架构&#xff08;按照指令集类型&#xff09; 5.相关指令 5.1.查看服务器CPU的信息 5.2.查看服务器内存的信息 二.RAID磁盘阵列&#xff08;Redundant Array …

大数据测试:构建Hadoop和Spark分布式HA运行环境

随着大数据技术的不断发展&#xff0c;Hadoop和Spark已成为处理大规模数据的热门框架。在生产环境中&#xff0c;高可用性&#xff08;HA&#xff09;是至关重要的&#xff0c;以确保数据处理和分析任务不受中断。本文将详细介绍如何构建 Hadoop和Spark分布式HA运行环境&#x…

Vue3——组件基础

组件基础 1. 组件定义与使用 1.1 代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>组件基础&l…

springSecurity简单直接说明

引入依赖 <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-security</artifactId></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombo…

如何对同一docker注册表使用多个身份验证/登录

常用容器登录方式 # 公共变量 REGISTRY"registry.cn-chengdu.aliyuncs.com"new_docker_username"root" new_docker_password"password" # 登录新的Docker账号 docker login -u "$new_docker_username" -p "$new_docker_password…

《“差异“也疯狂:一场妙趣横生的Diff算法冒险记》

序章&#xff1a;一场意外的挑战 在一个阳光明媚的午后&#xff0c;代码世界里的两位主角——“老练”的Oldie和“活泼”的Newbie&#xff0c;突然收到了一封神秘的挑战书。信上写道&#xff1a;“亲爱的代码居民们&#xff0c;你们是否厌倦了平淡无奇的生活&#xff1f;来吧&…

网络安全主题纪录片

网络安全主题纪录片 文章目录 网络安全主题纪录片第四公民黑客帝国系列龙纹身女孩碟中谍系列虎胆龙威4匿名者终结者2&#xff1a;审判日东方快车谋杀案黑客国家公敌我是谁&#xff1a;没有绝对安全的系统黑客军团速度与激情系列十亿美元大劫案勒索软件的背后黑客的恐惧为什么网…

电商价格监测的价值是什么

品牌做电商价格监测的原因多是为了渠道管控&#xff0c;即控价&#xff0c;管控价格前需要对渠道中的价格数据进行监测&#xff0c;通过监测价格&#xff0c;对渠道中低价数据进行全面的了解&#xff0c;如有授权低价率&#xff0c;非授权低价率&#xff0c;非授权低价店铺的总…

蝴蝶书--ChatGPT基础科普

temperature的参数调整输出的概率分布&#xff0c;这个参数值越大&#xff0c;分布就看起来越平滑&#xff0c;也就是高概率和低概率的差距拉小了&#xff08;对输出不那么确定&#xff09; Top-P在累计概率超过P的词里进行选择&#xff0c;对于概率分布比较均匀的情况&#x…