What is Block Formatting Context (BFC)

Block formatting Context (BFC) Block formatting context. Is a render area used to lay out block-level boxes. And it has nothing to do with the outside of this region. It can be understood that the BFC is a block-independent scope that has some characteristics of its own. Elements with BFC characteristics can be viewed as separate containers, the elements inside the container do not affect the layout of the elements outside, and BFC has some characteristics that normal containers do not have.

How to generate BFC

The BFC can be triggered if one of the following conditions is met

Float is not None. Position is not static or relative. Display is inline-block, table-cell, flex, table-caption, or inline-flex 4. Overflow is not visible

Landing the role of

1. To solve the problem of margin collapse, the margins of two adjacent boxes belonging to the same BFC will overlap, and large ones are the main ones. To solve this problem, divide the two boxes into different BFC. In the same BFC:

Be two BFC’s and wrap one box with overflow: Hidden;

 <style>
        .red {
            width: 100px;
            height: 100px;
            background-color: red;
            margin: 20px;
        }
        .box {
            overflow: hidden;
        }
        .yellow {
            width: 100px;
            height: 100px;
            background-color: yellow;
            margin: 20px;
        }
    </style>
</head>
<body>
    <div class="red"></div>
    <div class="box">
        <div class="yellow"></div>
    </div>
</body>
Copy the code

2. Solve the problem of height collapse of parent element

When the child element is set to float and the parent element has no height set, the parent element cannot extend the height of the child element

Set overflow: Hidden for the parent element; , trigger the BFC, and you can spread the height

<style>
        .box1 {
            width: 200px;
            border: 2px solid #ccc;
            overflow: hidden;
        }
        .box2 {
            width: 100px;
            height: 100px;
            background-color: green;
            float: left;
        }
    </style>
</head>
<body>
    <div class="box1">
        <div class="box2"></div>
    </div>
</body>
Copy the code

3. Solve the adjacent div cover problem (can be used as a two-column layout) two adjacent divs, one of the float, the other will be covered

Add overflow: hidden to the overwritten element; Trigger the BFC to prevent being blocked by the red box

 <style>
        .box1 {
            height: 100px;
            width: 100px;
            float: left;
            background: red
        }
        .box2 {
            width: 200px;
            height: 200px;
            background: #eee;
            overflow: hidden;
        }
    </style>
</head>
<body>
    <div class="box1"> I am a left float element </div> <div class="box2"</div> </body> I am an element with no set float and no BFC triggerCopy the code