面试官:说一下什么是 BFC

前言

在前端开发中,bfc可能大多数人都听说过,但是真正去表述这个概念时,总是描述的不是很清楚,我也有一样的困惑。于是带着这个困惑下了这篇文章,希望可以帮助到大家,一起来看看吧~

定义

区块格式化上下文(Block Formatting Context,BFC)是 Web 页面的可视 CSS 渲染的一部分,是块级盒子的布局过程发生的区域,也是浮动元素与其他元素交互的区域。

定义估计看不懂,我们直接看下面的栗子

好处

首先,我们先做一个demo,来形成以下的三个好处,然后使用bfc来解决这些问题

html 复制代码
<style>
      .outer {
        width: 300px;
        background-color: #333;
      }
      .inner {
        width: 100px;
        height: 100px;
      }
      .inner:nth-child(1) {
        background-color: #f00;
      }
      .inner:nth-child(2) {
        background-color: #0f0;
      }
      .inner:nth-child(3) {
        background-color: #00f;
      }
    </style>
  </head>
  <body>
    <div class="outer">
      <div class="inner"></div>
      <div class="inner"></div>
      <div class="inner"></div>
    </div>
  </body>

我们看到正常情况是这个样式,然后开启margin塌陷,给inner加上 margin: 20px;,如图所示,造成了margin 塌陷,然后我们分别使用下面的方法来解决一下,剩余两个好处一样,就不展开举例了。大家可以自己下去试试。

好处1. 开启bfc后,不会产生margin塌陷问题,什么是margin塌陷可以看我的这篇文章(父元素开启)

好处2. 开启bfc后,自己不会被其他浮动元素所覆盖(自身开启)

css 复制代码
//自身开启
.inner:nth-child(1) {
  background-color: #f00;
  float: left;
}
//其他浮动元素
.inner:nth-child(2) {
  background-color: #0f0;
  float: left;
}

好处3. 开启bfc后,就算其子元素开启浮动,自身高度也不会塌陷(父元素开启)

css 复制代码
//	父元素开启
.outer {
  width: 300px;
  background-color: #333;
  float: left;
}
//子元素浮动
.inner {
  width: 100px;
  height: 100px;
  margin: 20px;
  float: left;
}

如何开启

根元素

html 元素,自带开启 bfc

浮动元素

css 复制代码
.outer {
        width: 300px;
        background-color: #333;
        float: left;
      }

给元素增加float之后也开启了bfc,如图所示

绝对定位、固定定位的元素

css 复制代码
.outer {
        width: 300px;
        background-color: #333;
        position: absolute;
      }

给元素增加定位之后也开启了bfc,如图所示

行内块元素

css 复制代码
.outer {
        width: 300px;
        background-color: #333;
        display: inline-block;
      }

元素增加行内块之后也开启了bfc,如图所示

表格单元格

table、thead、tbody....

overflow的值不为visible的块元素

flex伸缩项目

给outer父元素设置display:flex即可

所列容器

设置 column-count: 1;即可

Colum-span为all的元素

disable的值设置为flow-root(最推荐)

怎么回答这个问题

每每面试问道这个问题时,确实不好回答,大家可以按这个思路来回答:

解释:可以理解为是元素的一个特殊功能,默认情况下是关闭的,当满足特定条件下将会被激活,也就是该元素开启了bfc,所以现在有两个问题,一是激活有什么用,二是具体怎么激活,我们继续来看!

  1. 然后可以说一下开启bfc的好处,就是上面说的三点好处。
  2. 最后说一下解决方案就行了,其余的不用说太多了。

总结

在众多的bfc的解决办法中,都有一些副作用,display:flow-root是最为推荐的,在实际工作中也不用过于追求实现bfc,就可以在遇到问题的时候再使用bfc的解决方案来解决即可,更多的大家可以理解bfc的概念,也方便在面试中可以更好的去回答这个问题。

相关推荐
政采云技术1 分钟前
深入理解 setState 执行机制
前端·react.js
清汤饺子2 分钟前
Everything Claude Code:让我把 AI 编程效率再翻一倍的东西
前端·javascript·后端
西洼工作室11 分钟前
React TabBar切换与高亮实现
前端·javascript·react.js
belldeep14 分钟前
前端:Bootstrap 3.0 , 4.0 , 5.0 有什么差别?
前端·bootstrap·html
wuhen_n19 分钟前
Tool Schema 设计模式详解
前端·javascript·ai编程
码喽7号19 分钟前
Vue学习三:element-plus组件和FontAwesome图标组件
前端·vue.js·学习
2501_9159184121 分钟前
WebKit 抓包,WKWebView 请求的完整数据获取方法
android·前端·ios·小程序·uni-app·iphone·webkit
mcooiedo22 分钟前
Go-Gin Web 框架完整教程
前端·golang·gin
小陈工22 分钟前
Python Web开发入门(一):虚拟环境与依赖管理,从零搭建纯净开发环境
开发语言·前端·数据库·git·python·docker·开源
wuhen_n23 分钟前
排列算法完全指南 - 从全排列到N皇后,一套模板搞定所有排列问题
前端·javascript·算法