CSS中的BFC及其作用

  • BFC是什么
    BFC 全稱為 塊格式化上下文 (Block Formatting Context) ,BFC是一個塊獨立的作用域,決定了元素如何對其內容進行定位,以及與其他元素的關系和相互作用。具有BFC特性的元素可以看做是隔離了的獨立容器,容器里面的元素不會在布局上影響到外面的元素
    將元素設置為不同BFC可以讓它們之間保持獨立,以消除它們之間的影響

  • 觸發(fā)BFC的條件
    滿足下列條件之一就可以觸發(fā)BFC
    1:根元素,即html元素
    2:float的值不為none
    3:overflow的值不為visible
    4:display的值為inline-block、table-cell、table-caption
    5:position的值為absolute或者fixed

  • BFC的作用
    可以阻止元素被浮動的元素覆蓋(可做兩欄布局自適應)
    綠色盒子浮動遮擋了紅色盒子


觸發(fā)紅色盒子的BFC,可防止被綠色盒子遮擋


<style>
        *{
            padding:0;
            margin :0;
        }
        .box {
            width: 400px;
            height: 100px;
            margin: 0  auto;
        }
        .green {
            width: 100px;
            height: 50px;
            float: left;
            background-color: green;
        }
        .red {
            width: 200px;
            height: 100px;
            /* float: left; */
            /* display: inline-block; */
            /* display: table-cell; */
            /* overflow: hidden; */
            /* position: absolute; */
            /* position: fixed; */
            background-color: red;
        }
    </style>
</head>
<body>
    <div class="box">
        <div class="green"></div>
        <div class="red">BFC</div>
    </div>
</body>

把注釋的任意一條打開會觸發(fā).red的BFC,讓兩者處于不同的BFC

  • 解決高度塌陷
    綠盒子設置浮動前,父盒子被撐開高度:


綠盒子設置浮動后,父盒子高度塌陷:



盒子觸發(fā)BFC可以解決這個問題

<style>
        .box {
            width: 200px;
            border: 1px solid #ccc;
            overflow:hidden;
        }
        .son {
            width: 100px;
            height: 100px;
            background-color: green;
            float: left;
        }
    </style>
</head>
<body>
    <div class="box">
        <div class="son"></div>
    </div>
</body>
  • 解決同一個BFC區(qū)域的垂直方向margin合并問題
    屬于同一個BFC的兩個相鄰的box的margin會重疊,以大的為主。要想解決這個問題,可以將兩個盒子分為不同的BFC中。

在同一個BFC中時:


分為兩個不同的BFC之后:


 <style>
        .green {
            width: 200px;
            height: 100px;
            margin-bottom: 20px;
            background-color: green;
        }
        .red {
            width: 200px;
            height: 100px;
            margin-top: 30px;
            background-color: red;
        }
        .box {
            overflow: hidden;

        } 
        .main {
            width: 300px;
            height: 250px;
            border: 1px solid #ccc;
        }
    </style>
</head>
<body>
        <div class="main">
            <div class="green"></div>
            <div class="box">
                <div class="red">BFC</div>
            </div>
        </div>   
</body>
最后編輯于
?著作權歸作者所有,轉載或內容合作請聯(lián)系作者
【社區(qū)內容提示】社區(qū)部分內容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發(fā)布,文章內容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內容

友情鏈接更多精彩內容