美文网首页
前端面试积累10-对BFC规范的理解

前端面试积累10-对BFC规范的理解

作者: 加油_未来 | 来源:发表于2018-12-09 17:00 被阅读0次

BFC,块级格式化上下文,一个创建了新的BFC的盒子是独立布局的,盒子里面的子元素的样式不会影响到外面的元素。在同一个 BFC 中的两个毗邻的块级盒在垂直方向(和布局方向有关系)的 margin 会发生折叠。

W3C CSS 2.1 规范中的一个概念,它决定了元素如何对其内容进行布局,以及与其他元素的关系和相互作用。

一、BFC 的概念

1.规范解释

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

2.通俗理解

BFC 是一个独立的布局环境,可以理解为一个容器,在这个容器中按照一定规则进行物品摆放,并且不会影响其它环境中的物品

如果一个元素符合触发 BFC 的条件,则 BFC 中的元素布局不受外部影响。

浮动元素会创建 BFC,则浮动元素内部子元素主要受该浮动元素影响,所以两个浮动元素之间是互不影响的

二、创建 BFC

根元素或包含根元素的元素

浮动元素 float = left | right 或 inherit(≠ none)

绝对定位元素 position = absolute 或 fixed

display = inline-block | flex | inline-flex | table-cell 或 table-caption

overflow = hidden | auto 或 scroll (≠ visible)

三、BFC 的特性

BFC 是一个独立的容器,容器内子元素不会影响容器外的元素。反之亦如此。

盒子从顶端开始垂直地一个接一个地排列,盒子之间垂直的间距是由 margin 决定的。

在同一个 BFC 中,两个相邻的块级盒子的垂直外边距会发生重叠。

BFC 区域不会和 float box 发生重叠。

BFC 能够识别并包含浮动元素,当计算其区域的高度时,浮动元素也可以参与计算了。

四、BFC 的作用

1.包含浮动元素(清除浮动)

浮动元素会脱离文档流(绝对定位元素也会脱离文档流),导致无法计算准确的高度,这种问题称为高度塌陷

解决高度塌陷问题的前提是能够识别并包含浮动元素,也就是清除浮动

问题举例:如上左图所示,容器(container)没有高度或者 height = auto ,并且其子元素(sibling)是浮动元素,所以该容器的高度是不会被撑开的,即高度塌陷。

解决方法:在容器(container)中创建 BFC。

HTML

<div class="container">

        <div class="Sibling"></div>

        <div class="Sibling"></div>

</div>

CSS

.container {

        overflow: hidden; /* creates block formatting context */

        background-color: green;

}

.container .Sibling {

        float: left;

        margin: 10px;

        background-color: lightgreen; 

}

特别提示:

通过 overflow:hidden 创建 BFC,固然可以解决高度塌陷的问题,但是大范围应用在布局上肯定不是最合适的,毕竟 overflow:hidden 会造成溢出隐藏的问题,尤其是与 JS 的交互效果会有影响。

我们可以使用 clearfloat 实现清除浮动,这里就不多介绍了,想要了解的可以阅读清除浮动

2.导致外边距折叠

相邻的两个盒子(可能是兄弟关系也可能是祖先关系)的垂直边距相遇时, 它们将形成一个外边距。这个外边距的高度等于两个发生折叠的外边距的高度中的较大者

HTML

<div class="Container">

    <p>Sibling 1</p>

    <p>Sibling 2</p>

</div>

CSS

.Container {

    background-color: red;

    overflow: hidden; /* creates a block formatting context */

}

p {

    background-color: lightgreen;

    margin: 10px 0;

}

如上图所示:红色盒子(Container)中包含两个绿色的兄弟元素(P),并且红色盒子设置 overflow: hidden; 则一个BFC 已经被创建,即导致外边距折叠。

理论上两个兄弟元素之间的边距应该是两个元素的边距之和(20px),但实际是 10px。这就是外边距折叠导致的。

2.1 折叠外边距的值

两个相邻的外边距都是 正数 时,折叠外边距是两者中较大的值。

两个相邻的外边距都是 负数 时,折叠外边距是两者中绝对值较大的值。

两个相邻的外边距是 一正一负 时,折叠外边距是两者相加的和。

2.2 外边距折叠的条件是 margin 必须相邻!

3.避免外边距折叠

这一听起来可能有些困惑,因为我们在前面讨论了 BFC 导致外边距折叠的问题。但我们必须记住的是外边距折叠(Margin collapsing)只会发生在属于同一BFC的块级元素之间。如果它们属于不同的 BFC,它们之间的外边距则不会折叠。所以通过创建一个不同的 BFC ,就可以避免外边距折叠。

修改前面的例子并添加第三个兄弟元素,CSS不变。

HTML

<div class="Container">

        <p>Sibling 1</p>

        <p>Sibling 2</p>

        <p>Sibling 3</p>

</div>

结果不会改变,还会折叠外边距,三个兄弟元素(P)将会以垂直距离为 10px 的距离分开。原因是三个兄弟元素都属于同一个 BFC。

创建一个不同的 BFC ,就可以避免外边距折叠。

HTML

<div class="Container">

        <p>Sibling 1</p>

        <p>Sibling 2</p>

        <div class="newBFC">

            <p>Sibling 3</p>

        </div>

</div>

CSS

.Container {

            background-color: red;

            overflow: hidden; /* creates a block formatting context */

}

p {

            background-color: lightgreen;

            margin: 10px 0;

}

.newBFC {

            overflow: hidden; /* creates new block formatting context */

}

当第二和第三个兄弟元素属于不同的 BFC 时,它们之间就没有外边距折叠。

相关文章

  • 前端面试积累10-对BFC规范的理解

    BFC,块级格式化上下文,一个创建了新的BFC的盒子是独立布局的,盒子里面的子元素的样式不会影响到外面的元素。在同...

  • BFC?

    BFC是前端面试中CSS部分的一个常考项,但是这个概念却是很不好理解的。 官方的定义 BFC (block for...

  • 前端面试题总结【12】:对BFC规范的理解?

    BFC,块级格式化上下文,一个创建了新的BFC的盒子是独立布局的,盒子里面的子元素的样式不会影响到外面的元素。在同...

  • CSS 其他小点

    对BFC规范的理解? BFC,块级格式化上下文,一个创建了新的 BFC 的盒子是独立布局的,盒子里面的子元素的样式...

  • BFC揭秘,其实也不过如此 | CSS

    相信每个前端er多多少少都有接触过BFC这个概念,也有许多人表示对这个概念难以理解。 其实BFC并不是什么神秘莫测...

  • 对BFC的理解

    FC,即formatting context,格式上下文——————它是W3C CSS2.1规范中的一个概念,定义...

  • 对BFC的理解

    一.什么是BFC? 1、BFC全称Block Formatting Context ,中文直译为块级格式上下文。它...

  • 对 BFC 的理解

    BFC (Block Formatting Context) 是 CSS 中的一个概念,用于解决布局问题。它是一个...

  • BFC

    原文:[布局概念] 关于CSS-BFC深入理解 面试的时候尽量不讲定义,而是讲例子。 定义 BFC全称叫做(Blo...

  • 我对BFC的理解~

    前端7班+余愿 鉴于我对BFC的理解难度,我觉得有必要把我的理解过程记录并保存下来,以后忘了可以随时来翻翻,也可以...

网友评论

      本文标题:前端面试积累10-对BFC规范的理解

      本文链接:https://www.haomeiwen.com/subject/fshkhqtx.html