css外邊距疊加

css外邊距疊加條件:

必須是普通文檔流中塊框垂直外邊距相互接觸才會發(fā)生外邊距疊加乎赴,
注意:外邊距必須相互接觸才能疊加

疊加理由:處于塊級格式化上下文中, 垂直接觸的外邊距會疊加

疊加的情況有三種:

  1. 同級元素直接外邊距疊加
  2. 父和子之間外邊距疊加
  3. 自己和自己之間外邊距疊加

情況1 同級元素直接外邊距疊加

   <div class="p1"></div>
   <div class="p2"></div>
.p1 {
  width: 100px;
  height: 100px;
  background: red;
  margin-bottom: 30px;
}

.p2 {
  width: 100px;
  height: 100px;
  background: red;
  margin-top: 30px;
}

結(jié)果為

Paste_Image.png

兩個元素直接為 30px, 即發(fā)生了外邊距的重疊
如何解決呢概漱?

之前說過,在BFC中 色冀,垂直方向上,接觸的外邊距會發(fā)生外邊距疊加关斜,一種簡單的思路就是炭菌,不然兩個外邊距接觸,即

    <div class="p1"></div>
    <hr/>
    <div class="p2"></div>
Paste_Image.png

發(fā)現(xiàn)外邊距不疊加了却舀,另外一種方法是虫几,利用BFC, 讓兩個元素不在同一個BFC里面

    <div class="p1"></div>
    <div class="bfc">
        <div class="p2"></div>
    </div>
.p1 {
  width: 100px;
  height: 100px;
  background: red;
  margin-bottom: 30px;
}

.p2 {
  width: 100px;
  height: 100px;
  background: red;
  margin-top: 30px;
}

.bfc {
    overflow: hidden;
}
Paste_Image.png

簡單的說就是挽拔,讓P2 處于 div.bfc這個BFC上下文里面辆脸,從而與 P1不在一起

情況2 父和子之間外邊距疊加

    <div class="p"></div>
    <div class="parent">
        <div class="child"></div>
    </div>
.p {
    width: 100px;
    height: 100px;
    background: red;
}
.parent {
    width: 100px;
    height: 100px;
    background: red;
    margin-top: 20px;
}

.child {
    width: 100px;
    height: 100px;
    background: yellow;
    margin-top: 60px;
}

Paste_Image.png

發(fā)現(xiàn),p 和 parent之間的外邊距為60螃诅, 這是為啥啡氢,因為parent 和 child的外邊距 發(fā)生了接觸状囱,所以他們疊加了, 解決方法也很簡單倘是,讓parent和child的外邊距不接觸就行了亭枷,于是給parent加一個外邊距

.parent {
    width: 100px;
    height: 100px;
    background: red;
    margin-top: 20px;
    border-top: 1px solid green;
}

Paste_Image.png

發(fā)現(xiàn)加了外邊距后, child的margin部分也成為了 parent的一部分辨绊,這里好涉及到另外一個點 究竟元素真正的邊框是啥,其實是外邊距匹表,只是外邊距之間的疊加门坷, 而且外邊距不顯示背景色讓我們誤以為 外邊距不算是不算是元素的一部分, 但實際上袍镀,外邊距才是元素的真正邊距

情況3 自己和自己外邊距疊加

如果一個元素默蚌,margin-bottom 和 marginp-top之間沒有內(nèi)容,相互接觸的話苇羡,他們也會疊加

    <div class="top"></div>
    <div class="middle"></div>
    <div class="bottom"></div>
.top, .bottom {
    width: 100px;
    height: 100px;
    background: red;
}

.bottom {
    background: yellow;
}

.middle {
    margin-top: 30px;
    margin-bottom: 30px;
}
Paste_Image.png

發(fā)現(xiàn)上 和 下兩個元素只有30px邊距绸吸,說明,middle自己的 margin-top和marign-bottom發(fā)生了疊加设江,如何解決呢锦茁, 讓他們不接觸即可

.middle {
    margin-top: 30px;
    margin-bottom: 30px;
    border-top: 1px solid transparent;
}
Paste_Image.png
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市叉存,隨后出現(xiàn)的幾起案子码俩,更是在濱河造成了極大的恐慌,老刑警劉巖歼捏,帶你破解...
    沈念sama閱讀 219,490評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件稿存,死亡現(xiàn)場離奇詭異,居然都是意外死亡瞳秽,警方通過查閱死者的電腦和手機瓣履,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,581評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來练俐,“玉大人袖迎,你說我怎么就攤上這事∠倭溃” “怎么了瓢棒?”我有些...
    開封第一講書人閱讀 165,830評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長丘喻。 經(jīng)常有香客問我脯宿,道長,這世上最難降的妖魔是什么泉粉? 我笑而不...
    開封第一講書人閱讀 58,957評論 1 295
  • 正文 為了忘掉前任连霉,我火速辦了婚禮榴芳,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘跺撼。我一直安慰自己窟感,他們只是感情好,可當我...
    茶點故事閱讀 67,974評論 6 393
  • 文/花漫 我一把揭開白布歉井。 她就那樣靜靜地躺著柿祈,像睡著了一般。 火紅的嫁衣襯著肌膚如雪哩至。 梳的紋絲不亂的頭發(fā)上躏嚎,一...
    開封第一講書人閱讀 51,754評論 1 307
  • 那天,我揣著相機與錄音菩貌,去河邊找鬼卢佣。 笑死,一個胖子當著我的面吹牛箭阶,可吹牛的內(nèi)容都是我干的虚茶。 我是一名探鬼主播,決...
    沈念sama閱讀 40,464評論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼仇参,長吁一口氣:“原來是場噩夢啊……” “哼嘹叫!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起诈乒,我...
    開封第一講書人閱讀 39,357評論 0 276
  • 序言:老撾萬榮一對情侶失蹤待笑,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后抓谴,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體暮蹂,經(jīng)...
    沈念sama閱讀 45,847評論 1 317
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,995評論 3 338
  • 正文 我和宋清朗相戀三年癌压,在試婚紗的時候發(fā)現(xiàn)自己被綠了仰泻。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,137評論 1 351
  • 序言:一個原本活蹦亂跳的男人離奇死亡滩届,死狀恐怖集侯,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情帜消,我是刑警寧澤棠枉,帶...
    沈念sama閱讀 35,819評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站泡挺,受9級特大地震影響辈讶,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜娄猫,卻給世界環(huán)境...
    茶點故事閱讀 41,482評論 3 331
  • 文/蒙蒙 一贱除、第九天 我趴在偏房一處隱蔽的房頂上張望生闲。 院中可真熱鬧,春花似錦月幌、人聲如沸碍讯。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,023評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽捉兴。三九已至,卻和暖如春录语,著一層夾襖步出監(jiān)牢的瞬間倍啥,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,149評論 1 272
  • 我被黑心中介騙來泰國打工钦无, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留逗栽,地道東北人盖袭。 一個月前我還...
    沈念sama閱讀 48,409評論 3 373
  • 正文 我出身青樓失暂,卻偏偏與公主長得像,于是被迫代替她去往敵國和親鳄虱。 傳聞我的和親對象是個殘疾皇子弟塞,可洞房花燭夜當晚...
    茶點故事閱讀 45,086評論 2 355

推薦閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標簽默認的外補...
    _Yfling閱讀 13,754評論 1 92
  • CSS 外邊距疊加有以下幾種情形: 相鄰(兄弟)元素的上下邊距疊加 包含(父子)元素的上下邊距疊加 元素自身的上下...
    柏丘君閱讀 1,251評論 0 0
  • 文章版權(quán)歸饑人谷_Lyndon以及饑人谷所有。 1. 浮動元素有什么特征倍踪?對父容器系宫、其他浮動元素、普通元素建车、文字分...
    HungerLyndon閱讀 2,383評論 4 10
  • 1. 在什么場景下會出現(xiàn)外邊距合并?如何合并领斥?如何不讓相鄰元素外邊距合并嫉到?給個父子外邊距合并的范例 外邊距合并:外...
    進擊的阿群閱讀 912評論 1 2
  • 1.在什么場景下會出現(xiàn)外邊距合并嚼黔?如何合并导而?如何不讓相鄰元素外邊距合并忱叭?給個父子外邊距合并的范例 概念:在CSS當...
    饑人谷_任磊閱讀 651評論 0 3