BFC(塊級格式化上下文)

BFC是css中的塊渲染規(guī)則弄兜,決定了各個元素間的相互作用药蜻,用于處理頁面布局。具有BFC特性的元素就相當(dāng)于一個獨立的容器替饿,與其他元素互不影響语泽。
默認(rèn)這個屬性是關(guān)閉的,如果想打開视卢,需要一些觸發(fā)條件踱卵。
處于BFC區(qū)域的元素具有的特征:
1.在同一個BFC區(qū)域內(nèi)的兩個相鄰元素或者父子元素,它們的垂直外邊距會發(fā)生重疊据过。
2.計算高度時惋砂,會把浮動子元素計算在內(nèi)。
3.此元素變成了一個獨立的元素绳锅,與外界元素不會互相影響西饵。
4.不會被浮動的元素覆蓋。

開啟BFC的條件:
1.body根元素本身是默認(rèn)開啟了BFC鳞芙;
2.設(shè)置元素浮動眷柔,float不為none;
3.設(shè)置定位原朝,position:absolute驯嘱、fixed;
4.設(shè)置display:inline-block喳坠、table-cell鞠评、flex;
5.設(shè)置overflow不為visible(hidden丙笋、auto谢澈、scroll)煌贴。

BFC作用:
1.阻止被浮動的元素覆蓋,可做兩欄布局自適應(yīng)锥忿。
兩個相鄰的元素牛郑,第一個設(shè)置了float后,會覆蓋在第二個元素上面敬鬓,為阻止被覆蓋淹朋,可在第二個元素上設(shè)置float、overflow: hidden钉答、position: absolute础芍、display: inline-block;。

<style>
.two{
    width:100px;
    height: 100px;
    background-color: rgb(18, 150, 36);
    float: left;
}
.three{
    width: 200px;
    height: 200px;
    background-color: rgb(201, 24, 24);
    float: left;
    /* overflow: hidden; */
    /*position: absolute;*/
    /*display: inline-block;*/
}
</style>
<body>
<div class="one"> 
     <div class="two"></div>
     <div class="three"></div>
</div>
</body>

2.解決高度塌陷
子元素設(shè)置浮動后数尿,父元素如果沒設(shè)置高度會出現(xiàn)高度塌陷仑性。可以給父元素設(shè)置overflow: hidden;右蹦、float: left;诊杆、position: absolute;、display: inline-block;何陆,但是使用最多的是overflow: hidden;其它的很少用晨汹。

<style>
.one{
    width: 150px;
    background-color: rgb(18, 150, 36);
    overflow: hidden;
    /*float: left;*/
    /*position: absolute;*/
    /*display: inline-block;*/
}
.two{
    width: 100px;
    height: 100px;
    background-color: rgb(135, 121, 214);
    float: left;
}
</style>
<body>
<div class="one"> 
    <div class="two"></div>
</div>
</body>

3.解決相鄰兩塊元素垂直外邊距、父元素與子元素垂直外邊距重疊的問題
垂直外邊距重疊的情況:
(1)相鄰兩元素都設(shè)置了margin贷盲,在垂直方向上淘这,兩元素垂直外邊距不會相加,而是取外邊距最大的值巩剖。
(2)父子關(guān)系的元素铝穷,子元素設(shè)置了margin,在垂直方向上佳魔,子元素的margin會傳給父元素氧骤,使得父元素產(chǎn)生外邊距。
為什么會產(chǎn)生這兩種垂直外邊距的情況吃引?
首先html根元素本身就開啟了BFC,處于html中的元素及其子元素其頂部是相鄰的刽锤,所以會發(fā)生上部垂直外邊距重疊镊尺。
對于相鄰的兄弟元素,它們同處于一個BFC區(qū)域并思,所以垂直外邊距也發(fā)生了重疊庐氮。

<style>
.one{
    width: 150px;
    background-color: rgb(225, 231, 226);
}
.two{
    width: 100px;
    height: 100px;
    background-color: rgb(135, 121, 214);
    margin: 10px 0;
}
.three{
    width: 100px;
    height: 100px;
    background-color: rgb(201, 24, 24);
    margin: 10px 0; 
}
.two_top{
    overflow: hidden;
}
</style>
<div class="one"> 
    <div class="two_top">
        <div class="two"></div>
    </div>
    <div class="three"></div>
</div>

在沒有添加two_top元素前,two和three是相鄰元素宋彼,都設(shè)置了margin弄砍,結(jié)果垂直外邊距重疊仙畦,并且two與父元素one的垂直外邊距也重疊。為解決重疊問題音婶,在two外面包裹一個two_top元素慨畸,設(shè)置overflow: hidden;使得two處于BFC區(qū)域,與外界元素隔離衣式,不相互影響寸士,垂直外邊距重疊問題消失。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末碴卧,一起剝皮案震驚了整個濱河市弱卡,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌住册,老刑警劉巖婶博,帶你破解...
    沈念sama閱讀 217,734評論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異荧飞,居然都是意外死亡凡人,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,931評論 3 394
  • 文/潘曉璐 我一進(jìn)店門垢箕,熙熙樓的掌柜王于貴愁眉苦臉地迎上來划栓,“玉大人,你說我怎么就攤上這事条获≈臆瘢” “怎么了?”我有些...
    開封第一講書人閱讀 164,133評論 0 354
  • 文/不壞的土叔 我叫張陵帅掘,是天一觀的道長委煤。 經(jīng)常有香客問我,道長修档,這世上最難降的妖魔是什么碧绞? 我笑而不...
    開封第一講書人閱讀 58,532評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮吱窝,結(jié)果婚禮上讥邻,老公的妹妹穿的比我還像新娘。我一直安慰自己院峡,他們只是感情好兴使,可當(dāng)我...
    茶點故事閱讀 67,585評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著照激,像睡著了一般发魄。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,462評論 1 302
  • 那天励幼,我揣著相機(jī)與錄音汰寓,去河邊找鬼。 笑死苹粟,一個胖子當(dāng)著我的面吹牛有滑,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播六水,決...
    沈念sama閱讀 40,262評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼俺孙,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了掷贾?” 一聲冷哼從身側(cè)響起睛榄,我...
    開封第一講書人閱讀 39,153評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎想帅,沒想到半個月后场靴,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,587評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡港准,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,792評論 3 336
  • 正文 我和宋清朗相戀三年旨剥,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片浅缸。...
    茶點故事閱讀 39,919評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡轨帜,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出衩椒,到底是詐尸還是另有隱情蚌父,我是刑警寧澤,帶...
    沈念sama閱讀 35,635評論 5 345
  • 正文 年R本政府宣布毛萌,位于F島的核電站苟弛,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏阁将。R本人自食惡果不足惜膏秫,卻給世界環(huán)境...
    茶點故事閱讀 41,237評論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望做盅。 院中可真熱鬧缤削,春花似錦、人聲如沸吹榴。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,855評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽腊尚。三九已至,卻和暖如春满哪,著一層夾襖步出監(jiān)牢的瞬間婿斥,已是汗流浹背劝篷。 一陣腳步聲響...
    開封第一講書人閱讀 32,983評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留民宿,地道東北人娇妓。 一個月前我還...
    沈念sama閱讀 48,048評論 3 370
  • 正文 我出身青樓,卻偏偏與公主長得像活鹰,于是被迫代替她去往敵國和親哈恰。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,864評論 2 354