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

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

BFC的工作原理如下:

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

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

html 复制代码
<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中。

相关推荐
青红光硫化黑19 分钟前
React基础之React.memo
前端·javascript·react.js
大麦大麦23 分钟前
深入剖析 Sass:从基础到进阶的 CSS 预处理器应用指南
开发语言·前端·css·面试·rust·uni-app·sass
m0_616188492 小时前
Vue3 中 Computed 用法
前端·javascript·vue.js
六个点2 小时前
图片懒加载与预加载的实现
前端·javascript·面试
Patrick_Wilson2 小时前
🔥【全网首篇】30分钟带你从0到1搭建基于Lynx的跨端开发环境
前端·react.js·前端框架
Moment3 小时前
前端 社招 面筋分享:前端两年都问些啥 ❓️❓️❓️
前端·javascript·面试
Moment3 小时前
一坤时学习 TS 中的装饰器,让你写 NestJS 不再手软 😏😏😏
前端·javascript·面试
子洋3 小时前
AnythingLLM + SearXNG 实现私有搜索引擎代理
前端·人工智能·后端
小满zs3 小时前
React第二十九章(css in js)
前端·react.js
古柳_Deserts_X3 小时前
Manus官方发布视频的1小时后就开始陆续有人注册了相关网站域名!原因就在于「新词新站」这4个字
前端·程序员·创业