マージンの相殺の習得
ブロックの上端と下端のマージンは、それぞれのマージンの大きい方の寸法(または等しい場合はいずれか 1 つ)の単一のマージンに結合される(相殺される、collapsed)ことがあり、マージンの相殺という動作として知られています。なお、浮動要素と絶対位置指定要素では相殺されません。
マージンの相殺は、基本的に 3 つの場合に発生します。
- 隣接兄弟要素
-
隣接兄弟要素のマージンは相殺されます(後ろの兄弟要素がそれ以前の浮動状態を解除する必要がある場合を除く)。
- 親と子孫を隔てるコンテンツがない場合
-
親ブロックとその子孫ブロックの間の垂直マージンは、両者の間に分離するコンテンツが存在しない場合に相殺されることがあります。具体的には、主に以下の 2 つの場合で現れます。
- 親要素の
margin-topは、そのフロー内の最初の子要素のmargin-topと相殺されます。ただし、親要素にborder-topやpadding-topが設定されている場合、インラインコンテンツ(テキストなど)が含まれている場合、浮動の解除が行われている場合を除きます。 - 親要素の
margin-bottomは、そのフロー内の最後の子要素のmargin-bottomと相殺されます。ただし、親要素にheightまたはmin-height、border-bottomやpadding-bottomが設定されている場合を除きます。
どちらの場合でも、親要素に新しいブロック整形コンテキストを作成した場合にも、雇用外のマージンの総裁は行われなくなります。
- 親要素の
- 空ブロック
-
あるブロックに
margin-topをmargin-bottomと隔てる境界、パディング、インラインコンテンツ、heightまたはmin-heightのいずれもがない場合、上端と下端のマージンは相殺されます。
注意すべきことがいくつかあります。
- これらのケースが組み合わさると、もっと複雑な (3 つ以上の) マージンの相殺が発生します。
- このルールはマージン幅がゼロの場合にも当てはまるので、親要素のマージンがゼロであるかどうかに関わらず、先頭/末尾の子要素のマージンは最終的に、 (上のルールに従って) その親要素より外側に出ます。
- 負のマージンが含まれる場合には、相殺されるマージンの大きさは、一番大きな正のマージンと一番小さな (もっともマイナス寄りの) マージンの合計値になります。
- すべてのマージンが負の場合、折りたたまれたマージンのサイズは、最小の(最もマイナス寄りの)マージンとなります。これは、隣接する要素と入れ子になった要素の両方に適用されます。
- マージンの相殺は、縦方向にのみ行われます。
- マージンはコンテナーの
displayがflexまたはgridに設定されていると相殺されません。
例
>HTML
html
<p>この段落の下端マージンは相殺されています …</p>
<p>
… この段落の上端マージンとの間で <code>1.2rem</code> のマージンになります。
</p>
<div>
この親要素には 2 つの段落があります。
<p>
この段落には上のテキストとの間に <code>.4rem</code> のマージンがあります。
</p>
<p>
下端マージンは親と相殺され、下端マージンは <code>2rem</code> になります。
</p>
</div>
<p>上の要素から下に <code>2rem</code> の位置です。</p>
CSS
css
div {
margin: 2rem 0;
background: lavender;
}
p {
margin: 0.4rem 0 1.2rem 0;
background: yellow;
}