What is landing

BFC stands for Block Formatting Context. It is a concept defined by the CSS2.1 specification regarding CSS rendering positioning. To understand what the BFC really is, let’s first look at what a visual formatting model is.

Visual formatting model

The Visual Formatting Model is the mechanism used to process documents and display them in visual media, and is also a concept in CSS.

The visual formatting model defines the generation of boxes, which include block boxes, inline boxes, anonymous boxes (boxes without names that cannot be selected by selectors), and some experimental boxes that may be added to the specification in the future. The type of box is determined by the display property.

Block box

Block boxes have the following features:

  • When the element’s CSS attributedisplayforblock.list-itemortableIs a block-level element.
  • Visually presented as blocks, arranged vertically;
  • Block-level box participation (block formatting context);
  • Each block-level element generates at least one block-level box, known as the Principal block-level box. Some elements, like<li>, generate additional boxes to place bullet points, although most elements generate only one main block-level box.

Inline box

  • When the element’s CSS attributedisplayThe calculated value ofinline.inline-blockorinline-table, it is called inline level element;
  • Visually it arranges content in multiple rows with other inline elements; Typical elements such as paragraph content, text (which can have multiple formats such as emphasis), or images are inline elements;
  • Inline level elements generate inline-level boxes that participate in inline formatting contexts. Inline boxes that also participate in generating inline formatting contexts are called inline boxes. alldisplay:inlineThe boxes generated by non-replacement elements of are inline boxes;
  • Inline boxes that do not participate in generating inline formatting contexts are called atomic inline-level boxes. These boxes consist of replaceable inline elements, ordisplayA value ofinline-blockinline-tableCan not be divided into multiple boxes;

Anonymous Box

Anonymous boxes also have anonymous block boxes and anonymous inline boxes. Because anonymous boxes have no names, you cannot select them using a selector, so all of their properties are inherit or the default values.

As in the following example, key anonymous block boxes are created to contain adjacent inline boxes:

<div>
    Some inline text
    <p>followed by a paragraph</p>
    followed by more inline text.
</div>Copy the code

Three positioning schemes

When positioning, the browser locates elements based on their box type and context. Boxes are the basic unit of positioning. When positioning, there are three positioning schemes, namely conventional flow and floating has absolute positioning.

Normal flow

  • In a normal flow, boxes are arranged one after another;
  • In a block-level formatting context, they are arranged vertically;
  • In inline formatting context, they are arranged horizontally;
  • whenpositionforstaticorrelativeAnd,floatfornoneTriggers regular flow;
  • forStatic positioning(static positioning),position: static.The position of the box is the position of the regular circulation bureau;
  • forRelative positioning(relative positioning),position: relativeThe box offset position is defined by these attributestop.bottom.leftandright.Retain the original position even if offsetOther regular streams cannot occupy this position.

Floating (Floats)

  • Boxes are called floating boxes;
  • It is at the beginning or end of the current line;
  • This causes the normal flow to surround it unless the clear property is set;

Absolute Positioning

  • Absolute positioning scheme, the box is removed from the conventional flow, does not affect the layout of the conventional flow;
  • It is positioned relative to its containing block, associated with CSS properties:top.bottom.leftandright;
  • If the attribute of the elementpositionforabsoluteorfixed, it is the absolute positioning element;
  • forposition: absolute, element positioning will be relative to the nearest onerelative,fixedorabsoluteIs the parent element of thebody;

Block formatting context

At this point, you have some idea of the positioning of THE CSS. From the information above, you can also see that the block format context is part of the visual rendering of the page’s CSS and is used to determine the layout of the block box and the area of interaction between the floats.

How to create a BFC

  • The root element or other element containing it;
  • floating(elements offloatDon’t fornone);
  • Absolute location element(elements ofpositionforabsoluteorfixed);
  • Inline blocksinline-blocks(elements ofdisplay: inline-block);
  • Table cell(elements ofdisplay: table-cell, default attributes of HTML table cells);
  • overflowThe value of thevisibleThe element;
  • Flex boxes(elements ofdisplay: flexorinline-flex);

Overflow :hidden, float:left/right, position:absolute That is, each time you see these attributes, you represent the element and create a BFC.

The scope of the landing

The scope of the BFC is described in MDN as follows.

A block formatting context contains everything inside of the element creating it that is not also inside a descendant element that creates a new block formatting context.

A BFC contains all the children that created the context element, but not the inner elements that created the child of the new BFC.

This looks a little bit strange, but I understand it this way, and I have the following code called class. BFC represents the creation of a new block format:

<div id='div_1' class='BFC'>
    <div id='div_2'>
        <div id='div_3'></div>
        <div id='div_4'></div>
    </div>
    <div id='div_5' class='BFC'>
        <div id='div_6'></div>
        <div id='div_7'></div>
    </div>
</div>Copy the code

This code indicates that #div_1 creates a block format context that includes #div_2, #div_3, #div_4, #div_5. That is, the child elements in #div_2 also belong to the BFC created by #div_1. But since #div_5 creates a new BFC, #div_6 and #div_7 are excluded from the outer BFC.

This, I think, is another way of saying that an element cannot exist in two BFC’s.

One of the most important effects of the BFC is to isolate the elements inside the BFC from the elements outside, so that the positioning of the elements inside and outside does not affect each other. This is the feature exploited by using BFC to clear floats, which will be covered later.

If an element can be in both FCCS, it means that the element can interact with elements in both FCCS, violating the isolation of the BFC, so this assumption is not valid.

The effect of the landing

As mentioned earlier, the most significant effect of BFC is to create an isolated space, cutting off the interaction between elements inside and outside the space. However, BFC has more features:

Floats, absolutely positioned elements, block containers (such as inline-blocks, table-cells, and table-captions) that are not block boxes, and block boxes with ‘overflow’ other than ‘visible’ (except when that value has been propagated to the viewport) establish new block formatting contexts for their contents.

In a block formatting context, boxes are laid out one after the other, vertically, beginning at the top of a containing block. The vertical distance between two sibling boxes is determined by the ‘margin’ properties. Vertical margins between adjacent block-level boxes in a block formatting context collapse.

In a block formatting context, each box’s left outer edge touches the left edge of the containing block (for right-to-left formatting, right edges touch). This is true even in the presence of floats (although a box’s line boxes may shrink due to the floats), unless the box establishes a new block formatting context (in which case the box itself may become narrower due to the floats).

A quick summary:

  1. The internal boxes are arranged vertically one after the other (think of it as a normal flow with one in the BFC);
  2. The elements in the same BFC influence each other, and margin collapse may occur.
  3. The left side of the margin box of each element touches the left side of the container block border box (for left-to-right formatting, otherwise the opposite). This is true even if there is a float;
  4. A BFC is a separate container on a page, in which child elements do not affect outside elements and vice versa.
  5. When calculating the height of the BFC, consider all elements contained in the BFC, including floating elements;
  6. Floating box area not superimposed on BFC;

So many properties are a little hard to understand, but the following reasoning helps: The root element of HTML is < HTML >, and the root element creates a BFC. Creating a new BFC creates a new < HTML > within the element. The child elements are positioned as if they were in a new < HTML > page, and the old and new HTML pages do not interact with each other.

This is not the most accurate understanding, or even an inversion of cause and effect (because HTML is the root element, it has the properties of BFC, not the other way around), but such reasoning helps to understand the concept of BFC.

Analyze BFC from actual code

After all this, it is still difficult to understand, so here are some examples to deepen the understanding of BFC.

Instance of a

<style>
    * {
        margin: 0;
        padding: 0;
    }
    .left{
        background: #73DE80; / * * / greenOpacity: 0.5; border: 3px solid#F31264;
        width: 200px;
        height: 200px;
        float: left; }. Right {/* pink */ background:#EF5BE2;Opacity: 0.5; border: 3px solid#F31264;
        width:400px;
        min-height: 100px;
    }
    .box{
        background:# 888;
        height: 100%;
        margin-left: 50px;
    }
</style>
<div class='box'>
    <div class='left'> </div>
    <div class='right'> </div>
</div>Copy the code

Display effect:

The green box (‘#left’) floats to the left, creating a new BFC, but not discussing the BFC it created for now. As the green box floats, it moves out of its normal flow position, so the pink box (‘#right’) is positioned in the upper left corner of the gray parent (property 3: the left side of the element touches the left side of the container), overlapping the floating green box.

Also, since the grey box (‘#box’) does not create a BFC, the height of the green box is not considered when calculating the height (feature 6: the floating area does not superimpose on the BFC area), resulting in height collapse, which is another common problem.

Example 2

Now create the BFC by setting Overflow: Hidden, and see what happens.

.BFC{
    overflow: hidden;
}

<div class='box BFC'>
    <div class='left'> </div>
    <div class='right'> </div>
</div>Copy the code

When the grey box creates a new BFC, the height changes and the green box area is taken into account when calculating the height (feature 5: The floating element is also used to calculate the height of the BFC).

The green and red boxes remained the same.

Examples of three

Now add some small pieces to the pink box and see what it looks like:

<style>
    .little{
        background: #fff;
        width: 50px;
        height: 50px;
        margin: 10px;
        float: left;
    }
</style>

<div class='box BFC'>
    <div class='left'> </div>
    <div class='right'>
        <div class='little'></div>
        <div class='little'></div>
        <div class='little'></div>
    </div>
</div>Copy the code

Since the pink box does not create a new BFC, the white block in the pink box is affected by the green box and is pushed to the right. Regardless of that, look at the margin of the white block.

Instances of four

Create a BFC for the pink box using the same method as in Example 2:

<div class='box BFC'>
    <div class='left'> </div>
    <div class='right BFC'>
        <div class='little'></div>
        <div class='little'></div>
        <div class='little'></div>
    </div>
</div>Copy the code

Once the pink box creates a new BFC, the pink box does not overlap with the green float box, and the white block inside is in an isolated space (feature 4: THE BFC is an isolated container on the page), and the white block is not squeezed by the green float box.

conclusion

The above is the analysis of BFC. The concept of BFC is abstract, but it should be better understood by example analysis. In practice, BFC can be used to close the float (example 2) and prevent overlap with the float element (Example 4). Meanwhile, due to the isolation function of BFC, BFC can be used to contain an element to prevent margin collapse between this element and elements outside BFC.

reference

Visual formatting model _MDN

Block formatting context _MDN

BFC details of the CSS

W3C block-formatting