谈谈你对BFC容器的理解

简介: 谈谈你对BFC容器的理解

前言

谈谈你对BFC容器的理解,这在前端面试中,是一个非常容易被问到的问题,很多小伙伴也许了解BFC容器的规则,但是想完整的表述出来,还是需要一番思索。在这篇文章中,我会给大家分享从几个点来回答面试官这个问题。

正文

BFC容器是什么?

首先我们来看看官方的概念:

块级格式化上下文(Block Formatting Context,BFC)是指在HTML文档中的一个独立渲染区域,其中的块级元素会按照一定的规则进行布局和渲染。BFC具有一套特定的渲染规则,这些规则影响着BFC内部元素的布局和外部元素的交互。

这段话有点复杂,我用自己的话来概括一下,小伙伴们方便记忆:

BFC是块级格式化上下文,是页面中一个渲染区域,有一套属于自己的渲染规则

BFC容器的渲染规则

  1. BFC容器在计算高度时,浮动元素的高度也会计算在内
  • 当一个元素形成了BFC,它会包含在BFC内部的所有内容,包括浮动元素。这意味着,如果一个元素触发了BFC,它的高度计算将考虑到内部浮动元素的高度。这种特性是BFC解决浮动引起的父元素塌陷的一种方式。因此,BFC容器内部的浮动元素不会导致父元素的高度塌陷为0。
  1. BFC容器内的子元素的margin-top不会和BFC这个父容器发生重叠
  • 在BFC中,相邻块级元素的垂直外边距(margin)不会发生重叠。这意味着,BFC容器内部的子元素的上外边距不会与其父容器的边框发生重叠,也不会与同级其他元素的上外边距发生重叠。这有助于保持布局的清晰性和可预测性。
  1. 遵照从上往下从左往右的布局排列
  • 在BFC中,内部的块级元素会按照文档流的顺序从上往下、从左往右进行布局排列。这意味着,BFC内部的块级元素不会随意漂浮或重叠,它们会按照其在HTML文档中出现的顺序依次排列,从左到右,从上到下。

以上三点是BFC容器的渲染规则,在面试时小伙伴们只需给面试官回答加粗的文字就行了。

触发条件

  1. position属性:元素的position属性值为absolute或fixed。
  2. overflow属性:元素的overflow属性值不为visible。
  3. display属性:元素的display属性值为inline-block、table-cell、table-caption、flex、inline-flex。
  4. float属性: 元素的float不为none

应用

清除浮动

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <style>
    .container {
      border: 1px solid black;
      overflow: hidden; /* 触发 BFC */
    }
    .float-box {
      float: left;
      width: 100px;
      height: 100px;
      background-color: red;
      margin-right: 10px;
    }
  </style>
</head>
<body>
  <div class="container">
    <div class="float-box"></div>
    <div class="float-box"></div>
    <div class="float-box"></div>
  </div>
</body>
</html>

在这个例子中,.container 的 overflow 属性被设置为 hidden,触发了它的BFC特性,使得它可以包含内部浮动的子元素,并且能够正常计算高度,从而防止父元素的高度塌陷。

对浮动属性不太了解的小伙伴们可以翻翻我前面的文章。

相关文章
|
安全 Linux Docker
容器安全拾遗 - Rootless Container初探
Docker和Kubernetes已经成为企业IT架构的基础设施,安全容器运行时越来越被关注。近期Docker 19.03中发布了一个重要的特性 “Rootless Container”,在提升容器的安全隔离性和可管理性方面前进了一大步。
7567 1
|
6月前
|
Kubernetes API 数据中心
在K8S中,pause容器作用是什么?
在K8S中,pause容器作用是什么?
|
8月前
|
Kubernetes Cloud Native Docker
什么是容器:从基础到进阶的全面介绍
什么是容器:从基础到进阶的全面介绍
959 1
|
存储 程序员 C#
用C++的角度讲解C#容器
用C++的角度讲解C#容器
118 0
|
存储 安全 Ubuntu
快速理解容器技术的实现原理
与 Docker 类似的容器技术并不是操作系统与生俱来的能力,而是通过组合一些 Linux 特性,实现**进程组隔离**的一种技术。 本篇文章将从介绍容器技术的发展开始,进而说明哪些 Linux 特性组成了容器技术的核心部分。希望您能够借由阅读本篇文章,对 Docker 等容器技术有更深刻的认识。 ## 1. 为什么我们需要容器 容器技术并不是凭空出现的,它来源自时代发展中人们对于如何更高效
429 0
|
9月前
|
存储 安全 索引
容器【容器介绍、Set接口介绍、 HashSet容器的使用、TreeSet容器的使用】(三)-全面详解(学习总结---从入门到深化)
容器【容器介绍、Set接口介绍、 HashSet容器的使用、TreeSet容器的使用】(三)-全面详解(学习总结---从入门到深化)
41 0
|
存储 程序员 C#
从C++的角度讲解C#容器
从C++的角度讲解C#容器
110 0
|
Kubernetes Cloud Native 安全
【探索 Kubernetes|容器基础进阶篇 系列1】容器的本质是进程
大家好,我是秋意零。 😈 CSDN作者主页 • 😎 博客主页 👿 简介 • 👻 普通本科生在读 • 在校期间参与众多计算机相关比赛,如:🌟 “省赛”、“国赛”,斩获多项奖项荣誉证书 • 🔥 各个平台,秋意零/秋意临 账号创作者 • 🔥 云社区 创建者 点赞、收藏+关注下次不迷路! 欢迎加入云社区
231 0
|
算法 程序员 C++
序言 容器
序言 容器
84 0
|
Linux Docker 容器
容器,到底怎么一回事
用故事的方式让你记住。同时解释实现容器的关键技术。
105 0