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;则会出现高度塌陷

相关推荐
沐土Arvin14 分钟前
深入理解 requestIdleCallback:浏览器空闲时段的性能优化利器
开发语言·前端·javascript·设计模式·html
专注VB编程开发20年15 分钟前
VB.NET关于接口实现与简化设计的分析,封装其他类
java·前端·数据库
小妖66625 分钟前
css 中 content: “\e6d0“ 怎么变成图标的?
前端·css
L耀早睡1 小时前
mapreduce打包运行
大数据·前端·spark·mapreduce
HouGISer1 小时前
副业小程序YUERGS,从开发到变现
前端·小程序
outstanding木槿1 小时前
react中安装依赖时的问题 【集合】
前端·javascript·react.js·node.js
霸王蟹2 小时前
React中useState中更新是同步的还是异步的?
前端·javascript·笔记·学习·react.js·前端框架
霸王蟹2 小时前
React Hooks 必须在组件最顶层调用的原因解析
前端·javascript·笔记·学习·react.js
专注VB编程开发20年2 小时前
asp.net IHttpHandler 对分块传输编码的支持,IIs web服务器后端技术
服务器·前端·asp.net
爱分享的程序员3 小时前
全栈项目搭建指南:Nuxt.js + Node.js + MongoDB
前端