CSS之BFC

BFC概念

BFC(Block Formatting Context)即块级格式化上下文,是Web页面的可视CSS渲染的一部分。它是一个独立的渲染区域,让其中的元素在布局上与外部的元素互不影响。简单来说,BFC提供了一个环境,允许内部的块级元素在垂直方向上一个接一个地放置,同时,BFC也会影响外部的布局特性,比如防止外边距折叠。

创建BFC方式

  • 根html元素。
  • 浮动元素(元素的float不是none)。
  • 绝对定位元素(元素的position为absolute或fixed)。
  • 行内块元素(元素的display为inline-block)。
  • 表格的表单元素(元素的display为table、table-cell、table-caption)。
  • overflow的值不为visible的块元素。
  • 弹性盒(display为flex或inline-flex元素的直接子元素)。
  • 网格布局(display为grid或inline-grid元素的直接子元素)。

BFC作用

  • 防止外边距折叠(Margin Collapse):在BFC中,相邻块级盒子的上下外边距会发生重叠,而BFC可以避免外边距折叠。
  • 清除浮动(Clearing Floats):BFC可以包含浮动元素,防止父容器高度塌陷。
  • 隔离元素:在BFC中,元素的布局不会影响外部元素的布局。

BFC使用示例

  1. 防止外边距折叠示例

HTML:

复制代码
 <div class="container">
      <div class="box ac">A</div>
 </div>
 <div class="box bc">B</div>

CSS:

css 复制代码
	  .box {
        width: 100px;
        height: 100px;
        color: white;
      }

      .ac {
        background: red;
        margin-bottom: 20px;
      }

      .bc {
        background: blue;
        margin-top: 20px;
      }

      .container {
        overflow: hidden;
      }

防止从属于同一个BFC的相邻块级盒模型外边距与外部块级盒模型外边距的折叠。

  1. 包含浮动元素

HTML:

复制代码
<div class="parent">
    <div class="float-child">浮动元素</div>
</div>

CSS:

css 复制代码
.parent {
    border: 2px solid #000;
    overflow: hidden; /* 触发BFC */
}

.float-child {
    float: left;
    width: 100px;
    height: 100px;
    background-color: #ff0000;
}

给.parent设置overflow: hidden;触发BFC,确保父容器能够包含其内的浮动元素。这解决了常见的浮动导致的父容器高度塌陷问题。

如果不设置.parent为overflow: hidden;则会出现高度塌陷

相关推荐
Bacon13 分钟前
Electron 集成第三方项目
前端
自由日记22 分钟前
css学习9
前端·css·学习
拖拉斯旋风24 分钟前
你不知道的javascript:深入理解 JavaScript 的 `map` 方法与包装类机制(从基础到大厂面试题)
前端·javascript
over69725 分钟前
《JavaScript的"魔法"揭秘:为什么基本类型也能调用方法?》
前端·javascript·面试
该用户已不存在29 分钟前
AI编程工具大盘点,哪个最适合你
前端·人工智能·后端
一头小鹿42 分钟前
【React Native+Appwrite】获取数据时的分页机制
前端·react native
冴羽1 小时前
这是一个很酷的金属球,点击它会产生涟漪……
前端·javascript·three.js
烛阴1 小时前
为什么 `Promise.then` 总比 `setTimeout(..., 0)` 快?微任务的秘密
前端·javascript·typescript
XiaoSong1 小时前
基于 React Native/Expo 项目的持续集成(CI)最佳实践配置指南
前端·react native·react.js