CSSのpaddingとmarginとは?違いを簡単に解説

CSSのpaddingとmarginとは?違いを簡単に解説

公開: 更新:
CodeCampが提供するDX人材育成が可能なプログラミングやITが学べる公開講座


CSSのpaddingとmarginの違い

Webページのレイアウトを作成する際、paddingとmarginの違いを正確に理解することが、美しく使いやすいデザインを実現する第一歩となります。以下の2つの違いを押さえておきましょう。

  • paddingは要素の内側の余白
  • marginは要素の外側の余白

それぞれの役割と使い方を理解することで、思い通りのレイアウト調整ができるようになります。以下では各プロパティについて詳しく解説していきます。

paddingは要素の内側の余白

paddingはボーダーとコンテンツの間に余白を作るプロパティで、要素の内側の空間を調整します。paddingで作成した余白には、要素に指定した背景色や背景画像が適用されます。

.box {
  padding: 20px;
  background-color: #f0f0f0;
  border: 1px solid #333;
}

上記のコードでは、ボーダーとコンテンツの間に20pxの余白が作られ、その余白部分にも背景色が表示されます。paddingはボタンやカードなどのデザイン要素で、クリック可能な領域を広げたり、テキストを読みやすくするために使用されます。

【PR】プログラミングや生成AIを無料で学べる「コードキャンプフリー」

marginは要素の外側の余白

marginはボーダーの外側に余白を作るプロパティで、要素同士の距離を調整します。marginで作成した余白は常に透明で、背景色や背景画像は適用されません。

.box {
  margin: 30px;
  background-color: #f0f0f0;
  border: 1px solid #333;
}

上記のコードでは、ボーダーの外側に30pxの余白が作られ、その余白部分には背景色が表示されません。marginは見出しと段落の間隔を開けたり、セクション同士の距離を調整するために使用されます。

CSSのpaddingとmarginをショートハンドで指定する

paddingとmarginは、上下左右を個別に指定することも可能性です。複数の値を1行でまとめて記述する方法を「ショートハンド」と言い、3つの指定方法があります。

  • 値を1つ指定する方法
  • 値を2つ指定する方法
  • 値を4つ指定する方法

それぞれの指定方法によって適用される箇所が異なるため、状況に応じて使い分けることで効率的にコードを記述できます。以下では各指定方法について詳しく解説していきます。

値を1つ指定する方法

値を1つだけ指定すると、上下左右すべてに同じ値が適用されます。すべての方向に同じ余白を設定したい場合に使用します。

.box {
  padding: 20px;
  margin: 15px;
}

上記のコードでは、paddingは上下左右すべてに20pxが適用され、marginは上下左右すべてに15pxが適用されます。コードが簡潔になるため、均等な余白を設定する際に便利です。

【PR】『Python』を学べる企業・個人向けのプログラミングコース

値を2つ指定する方法

値を2つ指定すると、1つ目の値が上下に、2つ目の値が左右に適用されます。上下と左右で異なる余白を設定したい場合に使用します。

.box {
  padding: 30px 15px;
  margin: 20px 10px;
}

上記のコードでは、paddingは上下に30px、左右に15pxが適用され、marginは上下に20px、左右に10pxが適用されます。縦横で異なる余白が必要な場合に効率的に記述できます。

値を4つ指定する方法

値を4つ指定すると、上から時計回りに上・右・下・左の順で適用されます。各方向に異なる余白を設定したい場合に使用します。

.box {
  padding: 10px 20px 15px 5px;
  margin: 5px 15px 10px 20px;
}

上記のコードでは、paddingは上10px、右20px、下15px、左5pxが適用され、marginも同様に各方向に異なる値が適用されます。細かい調整が必要な場合に使用しますが、可読性を考慮して必要最小限の使用にとどめることが推奨されます。

CSSのmarginで発生する相殺の仕組み

marginには相殺と呼ばれる独特の動作があり、上下に隣り合う要素のmarginが重なると大きい方の値だけが適用される現象です。以下の2つのケースで相殺が発生します。

  • 隣接する兄弟要素間の相殺
  • 親要素と子要素間の相殺

それぞれのケースで相殺の挙動が異なるため、レイアウトが意図通りにならない原因となることがあります。以下では各ケースについて詳しく解説していきます。

隣接する兄弟要素間の相殺

上下に並ぶ兄弟要素にそれぞれmarginを設定した場合、値が合算されず大きい方のmarginだけが適用されます。相殺はブロックレベル要素の上下方向のmarginでのみ発生し、左右方向では発生しません。

.box1 {
  margin-bottom: 40px;
}

.box2 {
  margin-top: 20px;
}

上記のコードでは、box1の下のmargin40pxとbox2の上のmargin20pxが重なりますが、合計の60pxにはならず、大きい方の40pxだけが要素間の余白として適用されます。この動作により、連続する段落や見出しで一貫した余白を保つことができます。

親要素と子要素間の相殺

親要素と子要素に同じ方向のmarginを設定した場合、borderやpaddingで区切られていなければ相殺が発生します。親要素のborderやpaddingが存在する場合は相殺が起こりません。

.parent {
  margin-top: 10px;
}

.child {
  margin-top: 50px;
}

上記のコードで親要素にborderやpaddingがない場合、親要素と子要素のmargin-topが相殺され、大きい方の50pxが親要素の外側に適用されます。この現象を防ぐには、親要素にborderやpaddingを1px以上設定するか、flexboxやgridなどのレイアウト手法を使用します。

※上記コンテンツの内容やソースコードはAIで確認・デバッグしておりますが、間違いやエラー、脆弱性などがある場合は、コメントよりご報告いただけますと幸いです。

ITやプログラミングに関するコラム


ITやプログラミングに関するニュース

ブログに戻る

コメントを残す

コメントは公開前に承認される必要があることにご注意ください。

CodeCampが提供するDX人材育成が可能なプログラミングやITが学べる公開講座 - IT・プログラミングを知って学べるコネクトメディア コードキャンプが提供する無料で学べるプログラミングスクール講座 - IT・プログラミングを知って学べるコネクトメディア コードキャンプDX人材育成研修 - IT・プログラミングを知って学べるコネクトメディア 配属3ヶ月で30%の生産性向上を実現するいよぎんコンピュータサービスの新人研修に迫る - IT・プログラミングを知って学べるコネクトメディア 金融業界の業務効率化を加速するニッセイアセットマネジメントの生成AI×GAS活用研修事例 - IT・プログラミングを知って学べるコネクトメディア 【製造業のDX人材育成事例】デジタル人材の即戦力化を実現する、日本ガイシ株式会社の異動者向オンボーディング研修 - ITやプログラミングを知って学べるコネクトメディア フューチャーアーキテクト株式会社が実現した新入社員向けIT研修プログラムでタスクフォース制度が主体的な学びと成長を生み出す - IT・プログラミングを知って学べるコネクトメディア コードキャンプDX人材育成研修 - IT・プログラミングを知って学べるコネクトメディア コードキャンプIT・プログラミング研修事例/【IT新入社員研修】オンラインとオフラインの最適バランスを実現したFutureOneの導入事例 - IT・プログラミングを知って学べるコネクトメディア コードキャンプIT・プログラミング研修事例/【新入社員研修】柔軟なハイブリッド型Java研修で実現した新卒20名の成長と成果|サークレイス株式会社 - ITやプログラミングを知って学べるコネクトメディア コードキャンプIT・プログラミング研修事例/現場により近いところにデジタルを根付かせるDX基礎講座研修|株式会社ブリヂストン - ITやプログラミングを知って学べるコネクトメディア コードキャンプIT・プログラミング研修事例/業務の効率化・DX推進に向けたIT人材育成への第一歩|株式会社カナエ - ITやプログラミングを知って学べるコネクトメディア 企業・法人向けのIT・プログラミング研修 - ITやプログラミングを知って学べるコネクトメディア

新着記事

対象者別で探す

子供(小学生・中学生・高校生)向け
プログラミング教室検索する

子供(小学生・中学生・高校生)がロボットやプログラミング言語を学ぶことができるオフラインからオンラインスクールを検索、比較することが可能です。

子供(小学生・中学生・高校生)
プログラミング教室検索する

ITやプログラムなどの
最新情報を検索する

日々、新しいITやプログラミング言語の情報が流れていきますが、特定の情報を時系列でニュースやコラムを確認することができます。

ITやプログラムなどの
最新情報を検索する