当前位置: 首页 > news >正文

CSS:BFC

BFC 的概念

BFC(块级格式化上下文)是 CSS 渲染过程中的一种独立布局环境,它是一块独立的渲染区域,规定了在该区域中,常规流块盒的布局。内部的元素布局不受外部影响,也不会影响外部元素
(注:常规流和标准流一般是一回事)

常规流块盒特点:

  • 水平方向上必须撑满包含块,
  • 在包含块的垂直方向上依次摆放
  • 若外边距无缝相邻,则进行外边距合并
  • 无论摆在哪儿,或者高度自动时,都会无视浮动元素(自然也会无视定位元素)

BFC 渲染区域:这个区域由某个 HTML 元素创建,以下元素会在其内部创建 BFC 区域(触发 BFC

  • 根元素(<html>)。
  • 浮动元素(float 不为 none)和绝对定位元素(positionabsolutefixed)。
  • overflow 不为 visible(如 autohidden)的块盒。
  • displayinline-blocktable-cellflexgrid 等。

BFC 的特性

  1. 内部元素垂直排列:BFC 内的块级元素默认垂直排列,间距由 margin 决定。
  2. 边距不会重叠:属于同一 BFC 的相邻元素 margin 会合并,但不同 BFC 的边距不会合并。
  3. 包含浮动元素:计算 BFC 高度时,浮动元素也会参与计算(解决浮动塌陷)。
  4. 隔离外部浮动:BFC 区域不会与外部浮动元素重叠。

BFC 的常见应用

解决浮动塌陷
父元素未设置高度时,子元素浮动会导致父元素高度塌陷。通过触发父元素的 BFC 可解决:

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

避免边距合并
两个相邻元素的 margin 会合并,通过包裹 BFC 容器隔离:

<div style="overflow: hidden;"><p style="margin: 20px;">内容</p>
</div>

实现自适应两栏布局
利用 BFC 区域不与浮动元素重叠的特性:

.left {float: left;width: 200px;
}
.right {overflow: hidden; /* 触发 BFC */
}

注意事项

  • 过度使用 BFC 可能导致布局复杂化(如频繁使用 overflow: hidden 会隐藏溢出内容)。
  • 现代布局方案(Flexbox、Grid)可替代部分 BFC 场景,但需考虑兼容性。

BFC 是 CSS 布局的核心机制之一,合理使用能有效解决多种布局问题。

http://www.dtcms.com/a/321396.html

相关文章:

  • 五种IO模型 阻塞IO 多路转接之select 多路转接之poll
  • 灰狼算法+四模型对比!GWO-CNN-LSTM-Attention系列四模型多变量时序预测
  • VIOO IQOO7手机 解锁BL ROOT教程
  • 光猫、路由器和交换机
  • 如何使用 pg_rman 进行 PostgreSQL 的备份与恢复
  • 解决 vscode 编辑 markdown 文件时退格键/backspace 删除卡顿问题
  • 【普中STM32精灵开发攻略】--第 14 章 动态数码管实验
  • PyQt 中 pyqtSignal 的使用
  • Orangepi5-RK3588安装ffmpeg硬编码版本
  • UE4/UE5 Android 超大(视频)文件打包/防拷贝方案
  • 【07】OpenCV C++实战篇——鼠标在图片上绘制矩形,计算矩形区域内灰度值的累加值显示在图片上,支持连续多次框选,快速计算结果,快速刷新画面不卡顿
  • Atto Round 1 (Codeforces Round 1041, Div. 1 + Div. 2) A-C
  • 【身心健康】能量管理——为你的情绪和身体注入积极力量
  • LVS高可靠
  • [激光原理与应用-184]:光学器件 - 光学器件中晶体的用途、分类、特性及示例
  • CSS--后端也有自己的CSS要学
  • 化工厂安全升级:分布式光纤传感的 “实时监测 + 精准预警” 方案
  • 【mongoose】E11000 duplicate key error collection: test.counters
  • [hot100]和为K的子数组-Python3
  • AI入门学习--RAG是什么?
  • TyDi QA:面向语言类型多样性的信息检索问答基准
  • Selenium + Python + Pytest + Yaml + POM
  • Java 大视界 -- 基于 Java 的大数据分布式计算在气象灾害数值模拟与预警中的应用(388)
  • 机器视觉的笔记本辅料贴合应用
  • camera人脸识别问题之二:【FFD】太阳逆光场景,人像模式后置打开美颜和滤镜,关闭heif拍摄格式对着人脸拍照,成像口红出现位置错误
  • 嵌入式系统GUI
  • 基于linux环境在centos7上部署gitlab
  • LLM驱动的数据分析组合(HoraeDB+Polars+Snorkel AI)
  • Transformer Encoder 与 Decoder:从结构到功能的深度解析
  • 【MATLAB技巧】打开脚本(m文件)后,中文乱码的解决方案