面试官:我让你翻译翻译,什么叫BFC!

前言

BFC (Blcok formatting context) 意思是块级格式化上下文。他是一个独立的渲染区域。BFC会影响 当前元素和内部元素的布局,但不会影响跟外部元素之间的关系。

如何创建BFC容器

  1. overflow属性:将一个元素属性设置为非visible就会创建一个BFC容器
  2. display属性:inline-block,table-cell,table-caption和flex属性,就会是一个BFC容器
  3. position属性:设置为absolute或fixed
  4. float属性:设置为left或right

以上就是主要的几个创建BFC容器的方法。

BFC可以解决哪些问题?

1. 垂直方向上margin的合并

当父容器内包裹一个子容器,分别给父容器和子容器设置一个margin-top。

js 复制代码
<style>
    .box {
        width: 200px;
        height: 200px;
        background-color: red;
        margin-top: 100px;
    }

    .box-son {
        width: 100px;
        height: 100px;
        background-color: blue;
        margin-top: 30px;
    }
</style>

你就会发现子容器的margin-top并没有效果,子容器依旧是贴着父容器的,甚至于我们不断的修改这个margin-top的值,只要不超过父容器的100px都是没有效果的。而且当我们设置子容器的margin-top大于父容器的时候,这个margin-top却依旧像是作用在父容器身上。这个就是margin的塌陷和合并。

  1. margin塌陷:当子元素的垂直方向上的margin大于父元素的margin时(包括父元素不设置margin的情况),子元素的margin会设置到父元素身上
  2. margin合并:父元素垂直方向上的margin大于子元素的,就会导致子元素的垂直方向上margin不生效。

解决方案:我们只需要将父元素设置为一个BFC容器即可。(给父元素设置overflow:hidden或别的方法)

2. 高度塌陷问题

当父元素不设置高度而子元素浮动时,父元素就会发生高度塌陷,父元素的高度变为0

我们能看到父元素的高度为0,但是我们能看到子元素。 解决方案:我们只需要将父元素设置为一个BFC容器即可。

3.避免和浮动元素重叠

两个同级的div,这里蓝色盒子设置浮动后把粉色盒子盖住了,如果我们不想让粉色盒子被蓝色盒子盖住的话。

解决方案:我们只需要将粉色盒子设置为一个BFC容器即可。

尾声

BFC我们只需要记住它最大的一个特点,他是一个独立的渲染区域,它规定死了它内部块级元素一个盒子一个盒子不重叠地垂直排列,且外部元素无法影响他。

相关推荐
浪裡遊7 分钟前
Next.js路由系统
开发语言·前端·javascript·react.js·node.js·js
mapbar_front10 分钟前
职场中的顶级能力—服务意识
前端
尽兴-1 小时前
[特殊字符] 微前端部署实战:Nginx 配置 HTTPS 与 CORS 跨域解决方案(示例版)
前端·nginx·https·跨域·cors·chrom
JIngJaneIL2 小时前
助农惠农服务平台|助农服务系统|基于SprinBoot+vue的助农服务系统(源码+数据库+文档)
java·前端·数据库·vue.js·论文·毕设·助农惠农服务平台
云外天ノ☼2 小时前
待办事项全栈实现:Vue3 + Node.js (Koa) + MySQL深度整合,构建生产级任务管理系统的技术实践
前端·数据库·vue.js·mysql·vue3·koa·jwt认证
gihigo19982 小时前
使用JavaScript和Node.js构建简单的RESTful API
javascript·node.js·restful
沐怡旸2 小时前
【穿越Effective C++】条款15:在资源管理类中提供对原始资源的访问——封装与兼容性的平衡艺术
c++·面试
一位搞嵌入式的 genius2 小时前
前端实战开发(三):Vue+Pinia中三大核心问题解决方案!!!
前端·javascript·vue.js·前端实战
塞纳河畔的歌2 小时前
保姆级教程 | 麒麟系统安装Edge浏览器
前端·edge
前端.火鸡2 小时前
Vue 3.5 新API解析:响应式革命、SSR黑科技与开发体验飞跃
javascript·vue.js·科技