成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

CSS中BFC的示例分析

這篇文章主要介紹CSS中BFC的示例分析,文中介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們一定要看完!

站在用戶的角度思考問題,與客戶深入溝通,找到龍江網(wǎng)站設(shè)計(jì)與龍江網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:成都網(wǎng)站建設(shè)、成都網(wǎng)站制作、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、域名與空間、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋龍江地區(qū)。

一、什么是BFC(Block Formatting Context)

寫CSS樣式時(shí),對(duì)一個(gè)元素設(shè)置css,我們首先要知道這個(gè)元素是塊級(jí)元素還是行內(nèi)元素,而BFC就是用來格式化塊級(jí)盒子的。

Formatting Context:指頁面中一個(gè)渲染區(qū)域,并且擁有一套渲染規(guī)則,它決定了其子元素如何定位,以及與其他元素的相互關(guān)系和作用。

BFC定義:塊級(jí)格式化上下文,它是指一個(gè)獨(dú)立的塊級(jí)渲染區(qū)域,只有Block-level Box參與,該區(qū)域擁有一套渲染規(guī)則來約束塊級(jí)盒子的布局,且與區(qū)域外部無關(guān)。

二、BFC的生成

我們說到BFC是一塊渲染區(qū)域,那么這塊渲染區(qū)域到底在哪里呢,具體大小又是多少?這些都是由生成BFC的元素來決定的。

滿足下列CSS聲明之一的元素便會(huì)生成BFC:

1、根元素或其它包含它的元素

2、float的值不為none;

3、overflow的值不為visible;

4、position的值不為static;

5、display的值為inline-block、table-cell、table-caption;

6、flex boxes (元素的display: flex或inline-flex);

注:也有人認(rèn)為display: table能生成BFC,我認(rèn)為最主要原因是table會(huì)默認(rèn)生成一個(gè)匿名的table-cell,正是這個(gè)匿名的table-cell生成了BFC。

三、BFC的布局規(guī)則

簡單歸納如下:

1、內(nèi)部的元素會(huì)在垂直方向一個(gè)接一個(gè)地排列,可以理解為是BFC中的一個(gè)常規(guī)流

2、元素垂直方向的距離由margin決定,即屬于同一個(gè)BFC的兩個(gè)相鄰盒子的margin可能會(huì)發(fā)生重疊

3、每個(gè)元素的左外邊距與包含塊的左邊界相接觸(從左往右,否則相反),即使存在浮動(dòng)也是如此,這說明BFC中的子元素不會(huì)超出它的包含塊

4、BFC的區(qū)域不會(huì)與float元素區(qū)域重疊

5、計(jì)算BFC的高度時(shí),浮動(dòng)子元素也參與計(jì)算

6、BFC就是頁面上的一個(gè)隔離的獨(dú)立容器,容器里面的子元素不會(huì)影響到外面的元素,反之亦然

四、BFC的應(yīng)用

說了這么多,那么我們BFC到底有什么用呢?下面我們通過幾個(gè)實(shí)例來解決一些問題:

實(shí)例1、解決margin重疊問題

玩css的朋友都知道m(xù)argin collapse,也就是相鄰的垂直元素同時(shí)設(shè)置了margin后,實(shí)際margin值會(huì)塌陷到其中較大的那個(gè)值。

其根本原理就是它們處于同一個(gè)BFC,符合“屬于同一個(gè)BFC的兩個(gè)相鄰元素的margin會(huì)發(fā)生重疊”的規(guī)則。

margin重疊現(xiàn)象

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>margin重疊現(xiàn)象</title>
    <style type="text/css">
        *{margin: 0;padding: 0;}
        .box p {
            margin: 20px 0px;
            background-color: skyblue;
        }
    </style>
</head>
<body>
    <div class="box" >
        <p>Lorem ipsum dolor sit.</p>
        <p>Lorem ipsum dolor sit.</p>
        <p>Lorem ipsum dolor sit.</p>
    </div>
</body>
</html>

CSS中BFC的示例分析

CSS中BFC的示例分析

CSS中BFC的示例分析

CSS中BFC的示例分析

通過實(shí)驗(yàn)結(jié)果我們發(fā)現(xiàn),上下margin重疊了。

我們可以在其中一個(gè)元素外面包裹一層容器,并觸發(fā)該容器生成一個(gè)BFC。那么兩個(gè)元素便屬于不同的BFC,就不會(huì)發(fā)生margin重疊了。

我們做如下修改:

<div class="box">
    <p>Lorem ipsum dolor sit.</p>
    <div style="overflow:hidden;">
        <p>Lorem ipsum dolor sit.</p>
    </div>
    <p>Lorem ipsum dolor sit.</p>
</div>

我們使用overflow:hidden;生成了一個(gè)BFC,成功解決了margin重疊問題。

CSS中BFC的示例分析

CSS中BFC的示例分析

CSS中BFC的示例分析

實(shí)例2、解決浮動(dòng)問題

我們知道給父元素設(shè)置overflow:hidden可以清除子元素的浮動(dòng),但往往都不知道原理是什么。

其實(shí)這就是應(yīng)用了BFC的原理:當(dāng)在父元素中設(shè)置overflow:hidden時(shí)就會(huì)觸發(fā)BFC,所以他內(nèi)部的元素就不會(huì)影響外面的布局,BFC就把浮動(dòng)的子元素高度當(dāng)做了自己內(nèi)部的高度去處理溢出,所以外面看起來是清除了浮動(dòng)。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>BFC浮動(dòng)問題</title>
    <style>
        .one {
            /* 文檔流 里面的文字標(biāo)簽將父元素?fù)纹饋?nbsp;*/
            background-color: pink;
        }
        .two {
            float: left;
        }
    </style>
</head>
<body>
    <!-- 文檔流 從上到下,當(dāng)遇到float、position:absolute時(shí),會(huì)離開文檔流 -->
    <div class="one">
    <div class="two">Hello World!</div>
    </div>
    你好世界!
</body>
</html>

CSS中BFC的示例分析

CSS中BFC的示例分析

我們做如下修改:

.one {
        background-color: pink;
        overflow: hidden;
    }

CSS中BFC的示例分析

CSS中BFC的示例分析

對(duì)比發(fā)現(xiàn),當(dāng)我們一個(gè)元素設(shè)置成為BFC之后,計(jì)算BFC元素高度的時(shí)候,浮動(dòng)元素也參與了計(jì)算。

實(shí)例3、解決侵占浮動(dòng)元素的問題

我們知道浮動(dòng)元素會(huì)脫離文檔流,然后浮蓋在文檔流元素上。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>BFC侵占浮動(dòng)元素的問題</title>
    <style>
        .box1 {
            float: left;
            width: 100px;
            height: 100px;
            background-color: pink;
        }
        .box2 {
            width: 200px;
            height: 200px;
            background-color: skyblue;
        }
    </style>
</head>
<body>
    <div class="box1">box1</div>
    <div class="box2">box2</div>
</body>
</html>

當(dāng)一個(gè)元素浮動(dòng),另一個(gè)元素不浮動(dòng)時(shí),浮動(dòng)元素因?yàn)槊撾x文檔流就會(huì)蓋在不浮動(dòng)的元素上。

我們做如下修改:

.box2 {
        width: 200px;
        height: 200px;
        background-color: skyblue;
        overflow: hidden;
    }

或如下修改:

.box2 {
        width: 200px;
        height: 200px;
        background-color: skyblue;
        /* overflow: hidden; */
        float: left;
    }

CSS中BFC的示例分析

我們?yōu)榉歉?dòng)元素建立BFC環(huán)境,根據(jù)BFC的不與float box重疊的規(guī)則,解決了侵占元素問題。

這一特性,我認(rèn)為還是很有用的,特別是應(yīng)用在兩欄布局上,對(duì)比我們常規(guī)為非浮動(dòng)元素或非定位元素設(shè)置margin來擠開的方法,其優(yōu)點(diǎn)在于不需要去知道浮動(dòng)或定位元素的寬度。

以上是“CSS中BFC的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對(duì)大家有幫助,更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!

文章題目:CSS中BFC的示例分析
標(biāo)題鏈接:http://jinyejixie.com/article30/pppgpo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、外貿(mào)網(wǎng)站建設(shè)、網(wǎng)站建設(shè)、小程序開發(fā)全網(wǎng)營銷推廣、Google

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

商城網(wǎng)站建設(shè)
景泰县| 宁化县| 长沙市| 兴海县| 九寨沟县| 平武县| 襄垣县| 长岛县| 凌源市| 浠水县| 乡城县| 盐边县| 鹤庆县| 延津县| 湛江市| 吉林市| 张掖市| 江西省| 通河县| 红桥区| 巢湖市| 建始县| 腾冲县| 崇文区| 许昌县| 黄骅市| 莱州市| 渝中区| 沧州市| 长泰县| 巴楚县| 正定县| 乌兰察布市| 东明县| 商南县| 威信县| 凤冈县| 钟山县| 澄迈县| 随州市| 凤城市|