diff options
author | Masahiro FUJIMOTO <mfujimot@gmail.com> | 2021-11-07 23:53:04 +0900 |
---|---|---|
committer | Masahiro FUJIMOTO <mfujimot@gmail.com> | 2021-11-15 23:58:10 +0900 |
commit | fb72298beae301c207efc5efd288438cc4e76410 (patch) | |
tree | a81fafc3e3f772c9a9af3a87f7df87a005e5030b /files/ja/web/css/css_box_model/mastering_margin_collapsing | |
parent | f42172f5271f70f69e541d8a0f0f925113180de8 (diff) | |
download | translated-content-fb72298beae301c207efc5efd288438cc4e76410.tar.gz translated-content-fb72298beae301c207efc5efd288438cc4e76410.tar.bz2 translated-content-fb72298beae301c207efc5efd288438cc4e76410.zip |
CSS Box Model 関係の文書を更新
- 2021/11/06 時点の英語版に同期
Diffstat (limited to 'files/ja/web/css/css_box_model/mastering_margin_collapsing')
-rw-r--r-- | files/ja/web/css/css_box_model/mastering_margin_collapsing/index.md | 110 |
1 files changed, 47 insertions, 63 deletions
diff --git a/files/ja/web/css/css_box_model/mastering_margin_collapsing/index.md b/files/ja/web/css/css_box_model/mastering_margin_collapsing/index.md index 1e62749980..ed20cd38df 100644 --- a/files/ja/web/css/css_box_model/mastering_margin_collapsing/index.md +++ b/files/ja/web/css/css_box_model/mastering_margin_collapsing/index.md @@ -1,55 +1,53 @@ --- -title: マージンの相殺 +title: マージンの相殺の習得 slug: Web/CSS/CSS_Box_Model/Mastering_margin_collapsing tags: - CSS - - CSS Box Model - CSS ボックスモデル - - Guide - - Reference + - ガイド + - リファレンス translation_of: Web/CSS/CSS_Box_Model/Mastering_margin_collapsing --- -<div>{{CSSRef}}</div> +{{CSSRef}} -<p>ブロックの<a href="/ja/docs/Web/CSS/margin-top">先頭</a>と<a href="/ja/docs/Web/CSS/margin-bottom">末尾</a>のマージンは、それぞれのマージンの最も大きい寸法 (または等しい場合はいずれか1つ) の単一のマージンに結合される (<ruby>折り畳まれる<rp> (</rp><rt>collapsed</rt><rp>)</rp></ruby>) ことがあり、<strong>マージンの相殺</strong>という動作として知られています。なお、<a href="/ja/docs/Web/CSS/float">浮動</a>要素と<a href="/ja/docs/Web/CSS/position#absolute">絶対位置指定</a>要素では折り畳まれません。</p> +ブロックの[上端](/ja/docs/Web/CSS/margin-top)と[下端](/ja/docs/Web/CSS/margin-bottom)のマージンは、それぞれのマージンの最も大きい寸法 (または等しい場合はいずれか 1 つ) の単一のマージンに結合される (折り畳まれる、collapsed) ことがあり、**マージンの相殺**という動作として知られています。なお、[浮動](/ja/docs/Web/CSS/float)要素と[絶対位置指定](/ja/docs/Web/CSS/position#types_of_positioning)要素では折り畳まれません。 -<p>マージンの相殺は、基本的に3つの場合に発生します。</p> +マージンの相殺は、基本的に 3 つの場合に発生します。 -<dl> - <dt>隣接兄弟要素</dt> - <dd>隣接兄弟要素のマージンは相殺されます (後ろの兄弟要素がそれ以前の浮動状態を <a href="/ja/docs/Web/CSS/clear">解除 (clear)</a> する必要がある場合を除く)。</dd> - <dt>親と子孫を隔てるコンテンツがない場合</dt> - <dd>あるブロックの {{cssxref("margin-top")}} と、1つ以上の子孫ブロックの {{cssxref("margin-top")}} を隔てる境界、パディング、インライン部分、 <a href="/ja/docs/Web/Guide/CSS/Block_formatting_context">ブロック整形コンテキスト</a>の生成、<em><a href="/ja/docs/Web/CSS/clear">浮動の解除 (clear)</a></em> のいずれもがない場合、もしくは、あるブロックの {{cssxref("margin-bottom")}} と1つ以上の子孫ブロックの {{cssxref("margin-bottom")}} を隔て境界、パディング、インラインコンテンツ、 {{cssxref("height")}}, {{cssxref("min-height")}}, {{cssxref("max-height")}} のいずれもがない場合、それぞれマージンが折り畳まれます。折り畳まれた側のマージンは、親要素の外側に出ます。</dd> - <dt>空ブロック</dt> - <dd>あるブロックの {{cssxref("margin-top")}} を {{cssxref("margin-bottom")}} と隔てる境界、パディング、インラインコンテンツ、 {{cssxref("height")}}, {{cssxref("min-height")}} のいずれもがない場合、上端と下端のマージンは相殺されます。</dd> -</dl> +- 隣接兄弟要素 + - : 隣接兄弟要素のマージンは相殺されます (後ろの兄弟要素がそれ以前の浮動状態を[解除](/ja/docs/Web/CSS/clear) する必要がある場合を除く)。 +- 親と子孫を隔てるコンテンツがない場合 + - : あるブロックの {{cssxref("margin-top")}} と、1 つ以上の子孫ブロックの {{cssxref("margin-top")}} を隔てる境界、パディング、インライン部分、 [ブロック整形コンテキスト](/ja/docs/Web/Guide/CSS/Block_formatting_context)の生成、_[浮動の解除](/ja/docs/Web/CSS/clear)_ のいずれもがない場合、もしくは、あるブロックの {{cssxref("margin-bottom")}} と1つ以上の子孫ブロックの {{cssxref("margin-bottom")}} を隔て境界、パディング、インラインコンテンツ、 {{cssxref("height")}}, {{cssxref("min-height")}}, {{cssxref("max-height")}} のいずれもがない場合、それぞれマージンが折り畳まれます。折り畳まれた側のマージンは、親要素の外側に出ます。 +- 空ブロック + - : あるブロックの {{cssxref("margin-top")}} を {{cssxref("margin-bottom")}} と隔てる境界、パディング、インラインコンテンツ、 {{cssxref("height")}}, {{cssxref("min-height")}} のいずれもがない場合、上端と下端のマージンは相殺されます。 -<p>注意すべきことがいくつかあります。</p> +注意すべきことがいくつかあります。 -<ul> - <li>これらのケースが組み合わさると、もっと複雑な (3つ以上の) マージンの相殺が発生します。</li> - <li>このルールはマージン幅がゼロの場合にも当てはまるので、親要素のマージンがゼロであるかどうかに関わらず、先頭/末尾の子要素のマージンは最終的に、 (上のルールに従って) その親要素より外側に出ます。</li> - <li>負のマージンが含まれる場合には、相殺されるマージンの大きさは、一番大きな正のマージンと一番小さな (もっともマイナス寄りの) マージンの合計値になります。</li> - <li>すべてのマージンが負の場合、折りたたまれたマージンのサイズは、最小の (最もマイナス寄りの) マージンとなります。これは、隣接する要素と入れ子になった要素の両方に適用されます。</li> -</ul> +- これらのケースが組み合わさると、もっと複雑な (3 つ以上の) マージンの相殺が発生します。 +- このルールはマージン幅がゼロの場合にも当てはまるので、親要素のマージンがゼロであるかどうかに関わらず、先頭/末尾の子要素のマージンは最終的に、 (上のルールに従って) その親要素より外側に出ます。 +- 負のマージンが含まれる場合には、相殺されるマージンの大きさは、一番大きな正のマージンと一番小さな (もっともマイナス寄りの) マージンの合計値になります。 +- すべてのマージンが負の場合、折りたたまれたマージンのサイズは、最小の (最もマイナス寄りの) マージンとなります。これは、隣接する要素と入れ子になった要素の両方に適用されます。 -<h2 id="Examples" name="Examples">例</h2> +<h2 id="Examples">例</h2> -<h3 id="HTML">HTML</h3> +### HTML -<pre class="brush: html notranslate"><p>The bottom margin of this paragraph is collapsed …</p> -<p>… with the top margin of this paragraph, yielding a margin of <code>1.2rem</code> in between.</p> +```html +<p>この段落の下端マージンは相殺されています …</p> +<p>… この段落の上端マージンとの間で <code>1.2rem</code> のマージンになります。</p> -<div>This parent element contains two paragraphs! - <p>This paragraph has a <code>.4rem</code> margin between it and the text above.</p> - <p>My bottom margin collapses with my parent, yielding a bottom margin of <code>2rem</code>.</p> -</div> +<div>この親要素には 2 つの段落があります。 + <p>この段落には上のテキストとの間に <code>.4rem</code> のマージンがあります。</p> + <p>下端マージンは親と相殺され、下端マージンは <code>2rem</code> になります。</p> +</div> -<p>I am <code>2rem</code> below the element above.</p></pre> +<p>上の要素から下に <code>2rem</code> の位置です。</p> +``` -<h3 id="CSS">CSS</h3> +### CSS -<pre class="brush: css notranslate">div { +```css +div { margin: 2rem 0; background: lavender; } @@ -57,33 +55,19 @@ translation_of: Web/CSS/CSS_Box_Model/Mastering_margin_collapsing p { margin: .4rem 0 1.2rem 0; background: yellow; -}</pre> - -<h3 id="Result" name="Result">例</h3> - -<p>{{EmbedLiveSample('Examples', 'auto', 350)}}</p> - -<h2 id="Specifications" name="Specifications">仕様書</h2> - -<table class="standard-table"> - <thead> - <tr> - <th scope="col">仕様書</th> - <th scope="col">状態</th> - <th scope="col">備考</th> - </tr> - </thead> - <tbody> - <tr> - <td>{{SpecName("CSS2.1", "box.html#collapsing-margins", "margin collapsing")}}</td> - <td>{{Spec2("CSS2.1")}}</td> - <td>初回定義</td> - </tr> - </tbody> -</table> - -<h2 id="See_also" name="See_also">関連情報</h2> - -<ul> - <li>{{css_key_concepts}}</li> -</ul> +} +``` + +### 結果 + +{{EmbedLiveSample('Examples', 'auto', 350)}} + +## 仕様書 + +| 仕様書 | 状態 | 備考 | +| -------------------------------------------------------------------------- | ------------------- | -------- | +| {{SpecName("CSS2.1", "box.html#collapsing-margins", "margin collapsing")}} | {{Spec2("CSS2.1")}} | 初回定義 | + +## 関連情報 + +- {{css_key_concepts}} |