当前位置 博文首页 > 杜小白的博客:浅析BFC原理及作用

    杜小白的博客:浅析BFC原理及作用

    作者:[db:作者] 时间:2021-09-19 10:18

    一、常见布局模式

    在讲BFC之前,我们先来看一下常见的CSS三种布局模型:

    CSS中的三种布局模型:流动模型(Flow)、浮动模型(Float)和层模型(Layer)。

    详解在我的另一篇博文中讲到,CSS中的三种布局模型。

    二、BFC概念

    BFC 即 Block Formatting Contexts (块级格式化上下文),它属于上述布局模式的流动模型。是W3C CSS2.1规范中的一个概念,决定了元素如何对其内容进行定位,以及与其他元素的关系和相互作用。具有BFC特性的元素可以看做是隔离了的独立容器,容器里面的元素不会在布局上影响到外面的元素,并且BFC具有普通容器所没有的的一些特性。通俗一点来讲,可以把BFC理解为一个封闭的大箱子,箱子内部的元素无论如何翻江倒海,都不会影响到外部。

    三、形成BFC的条件

    只要元素满足下面任一条件即可触发BFC特性:

    • body 根元素
    • 浮动元素:float 除 none 以外的值
    • 绝对定位元素:position (absolute、fixed)
    • display 为 inline-block、table-cells、flex
    • overflow 除了 visible 以外的值 (hidden、auto、scroll)

    四、BFC常见作用

    1、阻止外边距折叠

    ? 问题案例:margin塌陷问题:在标准文档流中,块级标签之间竖直方向的margin会以大的为准,这就是margin的塌陷现象。可以用overflow:hidden产生bfc来解决。

    <head>
    div{
        width: 100px;
        height: 100px;
        background: lightblue;
        margin: 100px;
    }
    </head>
    <body>
        <div></div>
        <div></div>
    </body>

    ????

    从效果上看,因为两个div元素都处于同一个BFC容器下(这里指body元素),所以第一个div的下边距和第二个div的上边距发生了重叠,所以两个盒子之间距离只有100px,而不是200px。

    首先这不是 CSS 的 bug,我们可以理解为一种规范,如果想要避免外边距的重叠,可以将其放在不同的 BFC 容器中。

    <div class="container">
        <p></p>
    </div>
    <div class="container">
        <p></p>
    </div>
    .container {
        overflow: hidden;
    }
    p {
        width: 100px;
        height: 100px;
        background: lightblue;
        margin: 100px;
    }?

    ????

    2、包含浮动元素

    ? 问题案列:高度塌陷问题,在通常情况下父元素的高度会被子元素撑开,而在这里因为其子元素为浮动元素所以父元素发生了高度坍塌,上下边界重合,这时就可以用BFC来清除浮动了。

    <div style="border: 1px solid #000;">
        <div style="width: 100px;height: 100px;background: grey;float: left;"></div>
    </div>

    ????

    由于容器内元素浮动,脱离了文档流,所以容器只剩下2px的边距高度。如果触发容器的BFC,那么容器将会包裹浮动元素。

    <div style="border: 1px solid #000;overflow: hidden">
        <div style="width: 100px;height: 100px;background: grey;float: left;"></div>
    </div>

    ????

    3、阻止元素被浮动元素覆盖

    ? 问题案例:div浮动兄弟这该问题:由于左侧块级元素发生了浮动,所以和右侧未发生浮动的块级元素不在同一层内,所以会发生div遮挡问题。可以给右侧元素添加?overflow: hidden,触发BFC来解决遮挡问题。

    <div style="height: 100px;width: 100px;float: left;background: lightblue">我是一个左浮动的元素</div>
    <div style="width: 200px; height: 200px;background: grey">我是一个没有设置浮动, 
    也没有触发 BFC 元素, width: 200px; height:200px; background: grey;</div>

    ????

    ? ? 这时候其实第二个元素有部分被浮动元素所覆盖,但是文本信息不会被浮动元素所覆盖,如果想避免元素被覆盖,可触发第二个元素的BFC特性,在第二个元素中加入overflow:hidden,就会变成:

    <div style="height: 100px;width: 100px;float: left;background: lightblue">我是一个左浮动的元素</div>
    <div style="width: 200px; height: 200px;background: grey;overflow:hidden">我是一个没有设置浮动, 
    也没有触发 BFC 元素, width: 200px; height:200px; background: grey;</div>

    ????

    这个方法可以用来实现两列自适应布局,效果不错,这时候左边的宽度固定,右边的内容自适应宽度。

    参考链接:

    • https://blog.csdn.net/riddle1981/article/details/52126522
    • https://zhuanlan.zhihu.com/p/25321647

    cs
    下一篇:没有了