CSS外邊距合并

塊的頂部外邊距和底部外邊距有時(shí)被組合(折疊)為單個(gè)外邊距,其大小是組合到其中的最大外邊距宋舷,這種行為稱為外邊距塌陷(margin collapsing)义郑,有的地方翻譯為外邊距合并要销。

發(fā)生外邊距塌陷的三種基本情況:

  • 相鄰的兄弟姐妹元素垂直方向外邊距合并
    毗鄰的兩個(gè)兄弟元素之間的外邊距會(huì)塌陷(除非后者兄弟姐妹需要清除過(guò)去的浮動(dòng))。例如:
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS Bin</title>
  <style>
    body {
      background: yellow;
    }
    div {
      width: 100px;
      height: 100px;
      border: 1px solid;
      margin: 50px;
    }
  </style>
</head>
<body>
  <div class="d1">d1</div>
  <div class="d2">d2</div>
</body>
</html>
測(cè)試01.png

但是后者清除浮動(dòng)后則不會(huì)合并:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS Bin</title>
  <style>
    div {
      width: 100px;
      height: 100px;
      border: 1px solid;
      margin: 50px;
      float: left;
    }
    .d2 {
      content: "";
      display: both;
      clear: both;
    }
  </style>
</head>
<body>
  <div class="d1">d1</div>
  <div class="d2">d2</div>
</body>
</html>
測(cè)試02.png
  • 塊級(jí)父元素與其第一個(gè)/最后一個(gè)子元素
    如果塊級(jí)父元素中谷炸,不存在上邊框、上內(nèi)邊距禀挫、內(nèi)聯(lián)元素旬陡、清除浮動(dòng)這四條屬性(也可以說(shuō),當(dāng)上邊框?qū)挾燃吧蟽?nèi)邊距距離為0時(shí))语婴,那么這個(gè)塊級(jí)元素和其第一個(gè)子元素的上邊距就可以說(shuō)”挨到了一起“描孟。此時(shí)這個(gè)塊級(jí)父元素和其第一個(gè)子元素就會(huì)發(fā)生上外邊距合并現(xiàn)象驶睦,換句話說(shuō),此時(shí)這個(gè)父元素對(duì)外展現(xiàn)出來(lái)的外邊距將直接變成這個(gè)父元素和其第一個(gè)子元素的margin-top的較大者匿醒。如:
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS Bin</title>
  <style>
    body {
      background: yellow;
    }
    .d1,.ct {
      width: 200px;
      height: 100px;
      background: blue;
      margin-top: 50px;
    }
    .d2 {
      width: 50px;
      height: 50px;
      background: red;
      margin-top: 50px;
    }
  </style>
</head>
<body>
  <div class="d1">d1</div>
  <div class="ct">
    <div class="d2">d2</div>
  </div>
</body>
</html>
測(cè)試03.png

類似的场航,若塊級(jí)父元素的 margin-bottom 與它的最后一個(gè)子元素的margin-bottom 之間沒(méi)有父元素的 border、padding青抛、inline content旗闽、height 、min-height 蜜另、max-height 分隔時(shí)适室,就會(huì)發(fā)生下外邊距合并 現(xiàn)象。

  • 空塊元素
    如果存在一個(gè)空的塊級(jí)元素举瑰,其 border捣辆、padding、inline content此迅、height 汽畴、min-height 都不存在。那么此時(shí)它的上下邊距中間將沒(méi)有任何阻隔耸序,此時(shí)它的上下外邊距將會(huì)合并忍些。
<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS Bin</title>
</head>
  <style>
    body {
      background: yellow;
    }
    .d1,.d3 {
      width: 300px;
      height: 50px;
      background: red;
    }
    .d2 {
      margin-top: 50px;
      margin-bottom: 50px;
    }
  </style>
<body>
  <div class="d1">d1和d2相距50px</div>
  <div class="d2"></div>
  <div class="d3">d1和d2相距50px</div>
</body>
</html>
測(cè)試04.png

合并規(guī)則:

  • 兩個(gè)margin都是正值的時(shí)候,取兩者的最大值坎怪;
  • 當(dāng) margin 都是負(fù)值的時(shí)候罢坝,取的是其中絕對(duì)值較大的,然后搅窿,從0位置嘁酿,按文檔流負(fù)向位移;
  • 當(dāng)有正有負(fù)的時(shí)候男应,先取出負(fù) margin 中絕對(duì)值中最大的闹司,然后,和正 margin 值中最大的 margin 相加沐飘。
  • 所有毗鄰的margin要一起參與運(yùn)算游桩,不能分步進(jìn)行。

不讓相鄰元素外邊距合并的方法:

  • 被非空內(nèi)容薪铜、padding众弓、border 或 clear 分隔開(kāi)。
  • 不在一個(gè)普通流中或一個(gè)BFC中隔箍。
  • margin在垂直方向上不毗鄰谓娃。
    例外的情況:
    根元素的外邊距不會(huì)參與折疊
    不設(shè)置任何屬性的空span和空div不影響任何布局,可以無(wú)視之蜒滩。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末滨达,一起剝皮案震驚了整個(gè)濱河市奶稠,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌捡遍,老刑警劉巖锌订,帶你破解...
    沈念sama閱讀 217,657評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異画株,居然都是意外死亡辆飘,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,889評(píng)論 3 394
  • 文/潘曉璐 我一進(jìn)店門谓传,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)蜈项,“玉大人,你說(shuō)我怎么就攤上這事续挟〗糇洌” “怎么了?”我有些...
    開(kāi)封第一講書人閱讀 164,057評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵诗祸,是天一觀的道長(zhǎng)跑芳。 經(jīng)常有香客問(wèn)我,道長(zhǎng)直颅,這世上最難降的妖魔是什么博个? 我笑而不...
    開(kāi)封第一講書人閱讀 58,509評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮功偿,結(jié)果婚禮上坡倔,老公的妹妹穿的比我還像新娘。我一直安慰自己脖含,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,562評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布投蝉。 她就那樣靜靜地躺著养葵,像睡著了一般。 火紅的嫁衣襯著肌膚如雪瘩缆。 梳的紋絲不亂的頭發(fā)上关拒,一...
    開(kāi)封第一講書人閱讀 51,443評(píng)論 1 302
  • 那天,我揣著相機(jī)與錄音庸娱,去河邊找鬼着绊。 笑死,一個(gè)胖子當(dāng)著我的面吹牛熟尉,可吹牛的內(nèi)容都是我干的归露。 我是一名探鬼主播,決...
    沈念sama閱讀 40,251評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼斤儿,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼剧包!你這毒婦竟也來(lái)了恐锦?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書人閱讀 39,129評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤疆液,失蹤者是張志新(化名)和其女友劉穎一铅,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體堕油,經(jīng)...
    沈念sama閱讀 45,561評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡潘飘,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,779評(píng)論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了掉缺。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片卜录。...
    茶點(diǎn)故事閱讀 39,902評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖攀圈,靈堂內(nèi)的尸體忽然破棺而出暴凑,到底是詐尸還是另有隱情,我是刑警寧澤赘来,帶...
    沈念sama閱讀 35,621評(píng)論 5 345
  • 正文 年R本政府宣布现喳,位于F島的核電站,受9級(jí)特大地震影響犬辰,放射性物質(zhì)發(fā)生泄漏嗦篱。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,220評(píng)論 3 328
  • 文/蒙蒙 一幌缝、第九天 我趴在偏房一處隱蔽的房頂上張望灸促。 院中可真熱鬧,春花似錦涵卵、人聲如沸浴栽。這莊子的主人今日做“春日...
    開(kāi)封第一講書人閱讀 31,838評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)典鸡。三九已至,卻和暖如春坏晦,著一層夾襖步出監(jiān)牢的瞬間萝玷,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書人閱讀 32,971評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工昆婿, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留球碉,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,025評(píng)論 2 370
  • 正文 我出身青樓仓蛆,卻偏偏與公主長(zhǎng)得像睁冬,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子看疙,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,843評(píng)論 2 354

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

  • 問(wèn)答題47 /72 常見(jiàn)瀏覽器兼容性問(wèn)題與解決方案痴突? 參考答案 (1)瀏覽器兼容問(wèn)題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 13,751評(píng)論 1 92
  • 塊的頂部外邊距和底部外邊距有時(shí)候會(huì)被折疊為單個(gè)外邊距搂蜓,其大小為兩值中的最大值,這種行為就被稱為外邊距合并辽装。 一般發(fā)...
    pypypy閱讀 712評(píng)論 0 49
  • 1.在什么場(chǎng)景下會(huì)出現(xiàn)外邊距合并?如何合并拓巧?如何不讓相鄰元素外邊距合并斯碌?給個(gè)父子外邊距合并的范例 概念:在CSS當(dāng)...
    饑人谷_任磊閱讀 650評(píng)論 0 3
  • 1. 在什么場(chǎng)景下會(huì)出現(xiàn)外邊距合并承耿?如何合并冠骄?如何不讓相鄰元素外邊距合并?給個(gè)父子外邊距合并的范例 外邊距合并:外...
    進(jìn)擊的阿群閱讀 909評(píng)論 1 2
  • 一加袋,浮動(dòng)元素有什么特征凛辣?對(duì)父容器、其他浮動(dòng)元素职烧、普通元素扁誓、文字分別有什么影響? 浮動(dòng)模型是一種可視化格式模型,浮動(dòng)...
    DeeJay_Y閱讀 872評(píng)論 0 4