CSS マージンの折りたたみの詳細な説明

CSS マージンの折りたたみの詳細な説明

前の

これは古くからある古典的な質問です。以前読者から質問があったので、ここでお答えします。

簡単な例から始めましょう

簡単な例を見てみましょう。

<スタイル>
    .slide1 div {
      マージン:10px 0;
    }
  </スタイル>
 <div class="slide1">
    <h3>マージン相殺タイプ 1: 兄弟要素</h3>
    <p>テキストの上下の間隔は 10 ピクセル</p>
    <p>テキストの上下の間隔は 10 ピクセル</p>
  </div> 

この例の 2 つのpタグを見てください。スタイル定義によると、最初のpmargin-bottomと 2 番目のpmargin-topどちらも 10px なので、実際の距離は 20px になるはずです。ただし、ブラウザーで確認すると、最終的な margin は10pxであることがわかります。 一例として、マージンの折りたたみが挙げられます。ブロックレベル要素の上部と下部のマージンが 1 つのマージンに結合される (または折りたたまれる) ことがあります。

分類

マージン崩壊には、基本的に 3 つのケースがあります。

  1. 隣接する要素
  2. 親要素と最初の子要素(または最後の子要素。後で、なぜ最初または最後の子要素なのかを思い出してください)
  3. 空のブロックレベル要素

急いで暗記しないでください。まず、前の記事の例は最初のケースです。マージンの崩壊は、隣接する 2 つの要素間で発生します。

2番目と3番目のケースは次のとおりです。


<スタイル>
    。父親 {
      背景色: 緑;

    }
    。子供 {
      上マージン: 50px;
      背景色: 赤;
      高さ: 300px;
    }
    
      .スライド3 {
      マージン: 10px 0;
    }
  </スタイル>
  <h3>2 番目のマージンの縮小: 親要素と最初の子要素</h3>
  <div class="slide2 父">
    <!-- 親要素は緑色です -->
    <div class="slide2 子">
      <!-- 子要素は赤です -->
    </div>
  </div>
  <h3>第 3 マージンの縮小: 空のブロックレベル要素</h3>
  <div class="slide3"></div>

それらの画像も以下に示します。

ケース2: 子要素の余白が親要素の外側に「転送」される

ケース3: 要素の上下の余白がなくなる

さて、これらの状況の共通点を見てみましょう(ボックスモデルを描くことをお勧めしますが、描くのが面倒なので-_-)、マージンの崩壊の共通の原因は、マージンが何の障害もなく直接接触していることです。

直接接触をどのように理解すればよいでしょうか?とても簡単です:

  • 最初の例では、2 つの<p>タグの垂直marginが直接接しています。
  • 2 番目の例では、親要素のpaddingborder両方とも 0 であるため、 marginとその子要素も直接接触しています。 (この例はボックスモデルを描くと分かりやすいです)
  • 3番目の例では、空要素自体の上部と下部の余白も直接接しています( paddingborderも0です)

様々なケースでの折り畳みの結果

折り畳み後の余白を計算する方法は簡単に確認できます。

  • 両方のマージンが正の場合、折り畳み後に大きい方のマージンが使用されます。
  • 一方のマージンが正でもう一方が負の場合、折り返しマージンはマージンの合計になります。
  • 両方のマージンが負の場合、縮小されたマージンは小さい方のマージンの合計になります。

余白が崩れるのを防ぐ方法

前述のように、マージンの崩壊の原因は、マージンが直接接触していることです。したがって、崩壊を防ぐ方法は、この直接接触をブロックすることです。方法の組み合わせは次のとおりです。

  • ネストされたケースでは、 border paddingが 0 でないか、親要素にテキスト行を追加するなど、分離するinline要素がある限り (ケース 2 で直接試すことができます)
  • フローティング、 display:tableなど、BFC の助けを借りてバリアを形成する方法。( BFCに慣れていない学生は最初に確認してください。後で記入します)

まとめ

上記で説明したのは基本的な状況であることを付け加えておきます。基本的な状況では、複数の隣接する要素間や、子孫要素の複数層のネストなどの組み合わせも作成できます。基本原理を理解すれば、小さなデモを作成して検証する限り、他の状況も簡単に理解できるようになります。それから、慣例があります。内容に間違いがあったら指摘してください(読んでいて不快に感じたり、文句を言いたくなったりしても全く問題ありません)。

以上がこの記事の全内容です。皆様の勉強のお役に立てれば幸いです。また、123WORDPRESS.COM を応援していただければ幸いです。

元のアドレス: https://segmentfault.com/a/1190000016842993

<<:  カルーセル効果を実現するための純粋なjs

>>:  Nofollowはコメントやメッセージ内のリンクを本当に機能させる

推薦する

JS での new の手書き実装

目次1 新しいオペレータの紹介2 新しいものは何をしましたか? 3 新しい演算子の実装をシミュレート...

Docker での Redis のマスタースレーブ構成チュートリアルの詳細説明

1. Redisイメージを取得するdocker pull redis 2. それぞれポート6379、...

WeChatアプレットでQRコードを識別するために長押しする実装プロセス

序文公式アカウントのQRコードは長押しで認識できることは皆さんご存じですが、ミニプログラムに対する制...

HTML サブタグと sup タグ

今日はあまり使わないHTMLタグ「subタグ」と「supタグ」を紹介します。定義と使用法: <...

JS+Canvas が抽選ホイールを引く

この記事では、宝くじターンテーブルを描画するJS + Canvasの具体的なコードを参考までに共有し...

CSS スティッキーフッター実装コード

この記事では、CSS スティッキー フッターの実装コードを紹介し、共有します。詳細は次のとおりです。...

Navicat を使用して MySQL データベースをエクスポートおよびインポートする方法

MySql は、私たちが頻繁に使用するデータ ソースです。開発者が練習、小規模なプライベート ゲーム...

さまざまなブラウザに対応するためにCSSで指定フォント@font-faceを導入する際の問題

Web ページを作成するときに、特定のフォントを使用したい場合は、 @font-faceを介して参照...

Ubuntu システムでタイムゾーンと時刻を変更する方法

Linux コンピュータには 2 つの時間があります。1 つはハードウェア時間 (BIOS に記録さ...

mysql 5.7.20 win64 のインストールと設定方法

mysql-5.7.20-winx64.zipインストール手順のないインストール パッケージ: ht...

MySQL の自動増分 ID に関するいくつかの小さな問題の要約

以下の質問はすべて InnoDB ストレージ エンジンに基づいています。 1. 最も大きな ID を...

JavaScript 基礎シリーズ: 関数とメソッド

目次1. 関数とメソッドの違い2. 良い関数の書き方2.1 正確な命名2.1.1 関数の命名2.1....

Reactはルーティングを使用してログインインターフェースにリダイレクトします

前回の記事では、webpack と react 環境を設定した後、ログイン インターフェースとその後...

主要ブラウザとそのカーネルの紹介

トライデント コア: IE、MaxThon、TT、The World、360、Sogou Brows...

Centos7 で keepalived ログを別のパスに設定する方法の詳細な説明

Keepalived のインストール: cd <keepalived_sourcecode_p...