面试官:BFC怎么触发,有什么作用?

629 阅读1分钟

BFC即是块级格式化上下文的缩写,旨在创建一个独立的布局环境,其中的元素布局不受外界影响。

触发BFC的常见属性
overflow:hidden;
display为inline-block、flex、table相关;
position为absolute、fixed。

那么BFC的作用有什么呢,主要是一下三点。

去除margin重叠

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>防止margin重叠</title>

    <style>
        * {
            margin: 0;
            padding: 0;
        }

        p {
            color: #f55;
            background: yellow;
            width: 200px;
            line-height: 100px;
            text-align: center;
            margin: 30px;
        }

        div {
            overflow: hidden;
        }
    </style>
</head>

<body>

    <p>看看我的 margin是多少</p>
    <div>
        <p>看看我的 margin是多少</p>
    </div>
</body>

</html>

image.png

我们给下面的盒子用一个父容器包裹,在父容器内形成BFC。那么就不会和上面的盒子发生margin重叠了。

自适应两栏布局

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>自适应两栏布局</title>


    <style>
        * {
            margin: 0;
            padding: 0;
        }

        body {
            width: 100%;
            position: relative;
        }

        .left {
            width: 100px;
            height: 150px;
            float: left;
            background: rgb(139, 214, 78);
            text-align: center;
            line-height: 150px;
            font-size: 20px;
        }

        .right {
            overflow: hidden;
            height: 300px;
            background: rgb(170, 54, 236);
            text-align: center;
            line-height: 300px;
            font-size: 40px;
        }
    </style>
</head>

<body>
    <div class="left">LEFT</div>
    <div class="right">RIGHT</div>
</body>

</html>

image.png 给右边元素加上BFC,就不会与左边元素重叠。

清除浮动

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>清除浮动</title>


    <style>
        .par {
            border: 5px solid rgb(91, 243, 30);
            width: 300px;
            overflow: hidden;
        }

        .child {
            border: 5px solid rgb(233, 250, 84);
            width: 100px;
            height: 100px;
            float: left;
        }
    </style>
</head>

<body>
    <div class="par">
        <div class="child"></div>
        <div class="child"></div>
    </div>
</body>

</html>

image.png 给父容器添加overflow:hidden形成BFC,清除浮动。


记录记录!