CSS外邊距合并

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

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

  • 相鄰的兄弟姐妹元素垂直方向外邊距合并
    毗鄰的兩個(gè)兄弟元素之間的外邊距會(huì)塌陷(除非后者兄弟姐妹需要清除過去的浮動(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)這四條屬性(也可以說,當(dāng)上邊框?qū)挾燃吧蟽?nèi)邊距距離為0時(shí)),那么這個(gè)塊級(jí)元素和其第一個(gè)子元素的上邊距就可以說”挨到了一起“。此時(shí)這個(gè)塊級(jí)父元素和其第一個(gè)子元素就會(huì)發(fā)生上外邊距合并現(xiàn)象,換句話說,此時(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 之間沒有父元素的 border、padding、inline content、height 、min-height 、max-height 分隔時(shí),就會(huì)發(fā)生下外邊距合并 現(xiàn)象。

  • 空塊元素
    如果存在一個(gè)空的塊級(jí)元素,其 border、padding、inline content、height 、min-height 都不存在。那么此時(shí)它的上下邊距中間將沒有任何阻隔,此時(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 分隔開。
  • 不在一個(gè)普通流中或一個(gè)BFC中。
  • margin在垂直方向上不毗鄰。
    例外的情況:
    根元素的外邊距不會(huì)參與折疊
    不設(shè)置任何屬性的空span和空div不影響任何布局,可以無(wú)視之。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

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

友情鏈接更多精彩內(nèi)容