面试官:讲讲BFC的特性及其作用?

普通流布局

在讲BFC之前,我们先了解一下CSS中最常见的普通流布局

元素在页面上自上而下、从左往右排列,块级元素独自占据一整行,而行内元素在水平方向上一个接一个排列,直到排满了才换行。元素默认情况下都是属于普通流的。

什么是BFC

块级格式化上下文(Block Formatting Context,简称BFC)也是属于普通流的,它是一个独立的渲染区域,在这个区域里面的元素和外面的元素互不干扰。

如何触发BFC

常见的方法有:

  • 根元素(<html>
  • 浮动元素(元素的float不是none
  • 绝对定位元素(元素的positionabsolutefixed
  • display为inline-blocktable-celltable-captionflexinline-flexgridinline-grid等值的元素
  • overflow不是visible的元素

当然,还有一些其他的方法,常用的有display: flow-root;,overflow: auto;

BFC的特性

  • BFC是一个独立的区域,其内部元素和外部元素互不干扰。
  • BFC的区域不会与float box重叠。
  • 计算BFC的高度时,浮动元素也参与计算。

BFC的应用

清除浮动

我们来看如下代码:

html 复制代码
    <div class="container">
        <div class="image"></div>
        <div class="content">
            "行李箱拖过几道车辙,是归人好似过路客。"
        </div>
    </div>
    <style>
        .container{
            background-color: aqua;
        }
        .image{
            width: 100px;
            height: 100px;
            background-color: pink;
            float: left;
        }
        .content{
            width: 200px;   
        }
    </style>

效果是这样的:

而实际上我们想要的效果应该是这样:

那么为什么会出现上面那种效果呢?是这样的,.image浮动后,父容器不会将其高度计算在内,父容器的高度仅仅由另一个非浮动元素撑开,所以就是上面那种效果。那么怎么达到我们想要的效果呢?只需要让父容器将浮动的子容器的高度计算在内就行了,即清除浮动。而BFC就有这个作用。

css 复制代码
    display: flow-root; // 在父容器中加上这条属性

当我们在父容器中加上这条属性之后,就会触发BFC,将里面浮动元素的高度计算在内,效果如下:

我们会发现,好像和我们想要的效果还是有点差距,这就涉及到BFC的另一个功能特性了。

阻止元素被浮动元素覆盖

上述代码中,我们.content元素加了200px的宽度,但实际上,我们可以看到,.content并没有这么宽,为什么呢?这是因为浮动元素将该元素的覆盖了一些。

css 复制代码
    display: flow-root; // 给被覆盖的元素添加该属性

具有BFC的元素的区域不会和浮动元素重叠,所以我们只需要让.content成为BFC就好了,效果如下:

避免外边距重叠

html 复制代码
    <div class="itemOne"></div>
    <div class="itemTwo"></div>
    <style>
        .itemOne{
            width: 100px;
            height: 100px;
            background-color: pink;
            margin: 10px;
        }
        .itemTwo{
            width: 100px;
            height: 100px;
            background-color: aqua;
            margin: 10px;
        }
    </style>

我们给这两个容器都设置了外边距10px,理论上,上面容器和下面容器之间的边距应该有20px,我们来看效果图:

我们会发现这两容器之间只有10px的边距,怎么解决呢?

html 复制代码
    <div class="itemOne"></div>
    <div style="display: flow-root;"></div>
    <div class="itemTwo"></div>

只需要在这两个容器之间放一个空的BFC,由于BFC和外部的元素互不干扰,所以BFC上面的容器的外边距自然就不会和BFC重叠,下面也是同理,这样就解决了外边距重叠的问题,效果如下:

相关推荐
杨进军15 分钟前
React 创建根节点 createRoot
前端·react.js·前端框架
ModyQyW30 分钟前
用 AI 驱动 wot-design-uni 开发小程序
前端·uni-app
说码解字36 分钟前
Kotlin lazy 委托的底层实现原理
前端
爱分享的程序员1 小时前
前端面试专栏-算法篇:18. 查找算法(二分查找、哈希查找)
前端·javascript·node.js
翻滚吧键盘1 小时前
vue 条件渲染(v-if v-else-if v-else v-show)
前端·javascript·vue.js
vim怎么退出1 小时前
万字长文带你了解微前端架构
前端·微服务·前端框架
你这个年龄怎么睡得着的1 小时前
为什么 JavaScript 中 'str' 不是对象,却能调用方法?
前端·javascript·面试
Java水解1 小时前
前端常用单位em/px/rem/vh/vm到底有什么区别?
前端
CAD老兵1 小时前
Vite 如何借助 esbuild 实现极速 Dev Server 体验,并支持无 source map 的源码调试
前端
南屿im1 小时前
JavaScript 手写实现防抖与节流:优化高频事件处理的利器
前端·javascript