塊的頂部外邊距和底部外邊距有時(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ú)視之蜒滩。