カテゴリ: CSS 更新日: 2026/05/05

CSSのマージンを完全ガイド!初心者でもわかるボックス間の余白調整の方法

複数ボックス間の余白調整に便利なマージンの使い方
複数ボックス間の余白調整に便利なマージンの使い方

先生と生徒の会話形式で理解しよう

生徒

「先生、ホームページを作っていると、ボックス同士がくっついて見づらくなることがあります。どうすればいいんですか?」

先生

「とても良い質問ですね。CSSでは、ボックス同士の間に“余白”を作るためにmargin(マージン)という仕組みがあります。」

生徒

「マージンって聞いたことありますけど、どうやって使うんですか?」

先生

「では、実際にCSSのマージンの基本から見ていきましょう。これを覚えると、ボックスの間隔を自由に調整できるようになりますよ。」

1. マージンとは?CSSで作るボックスの外側の余白

1. マージンとは?CSSで作るボックスの外側の余白
1. マージンとは?CSSで作るボックスの外側の余白

マージン(margin)とは、HTML要素(ボックス)の外側に作られる余白のことです。Webデザインにおいて、要素と要素がくっつきすぎないように「適切な距離感」を保つ役割を持っています。

イメージとしては、机の上にノートを並べる時の「ノート同士の隙間」のようなものです。マージンを正しく設定することで、ユーザーにとって読みやすく、圧迫感のないスッキリとしたレイアウトを実現できます。

ポイント: CSSには「margin」と「padding」がありますが、marginは境界線の「外側」、paddingは境界線の「内側」の余白を指します。

プログラミング未経験の方でも、以下のサンプルコードを見れば仕組みは簡単です。2つのボックスの間にどれくらいの隙間ができるか注目してみましょう。


<style>
    .box-container {
        border: 2px solid #333;
        background-color: #f9f9f9;
        /* ボックスの外側に20pxの余白を作る */
        margin: 20px;
        padding: 15px;
    }
    .sample-text {
        color: #555;
        font-weight: bold;
    }
</style>

<div class="box-container">
    <p class="sample-text">1つ目のボックス:外側に20pxの隙間があります。</p>
</div>
<div class="box-container">
    <p class="sample-text">2つ目のボックス:上のボックスとの間に距離が生まれます。</p>
</div>
ブラウザ表示

このように、margin: 20px;と1行記述するだけで、上下左右すべての方向に20ピクセルの空間が確保されます。もしマージンを指定しないと、これらのボックスは隙間なくピッタリとくっついてしまい、非常に読みづらいサイトになってしまいます。

2. マージンの方向(上下左右)を指定して個別に調整する方法

2. マージンの方向(上下左右)を指定して個別に調整する方法
2. マージンの方向(上下左右)を指定して個別に調整する方法

CSSのmargin(マージン)は、一括で指定するだけでなく、「上だけ」「左だけ」といったように、上下左右の4方向を個別に指定することが可能です。Webデザインにおいて、見出しの上にだけ大きな余白を作ったり、文章の左側を少し空けて読みやすくしたりする際に非常によく使われます。

まずは、それぞれの方向を指定するためのプロパティを覚えましょう。英語の「上・右・下・左」がそのまま使われているので、初心者の方でも直感的に理解できます。

  • margin-top:要素の「上側」に余白を作る
  • margin-right:要素の「右側」に余白を作る
  • margin-bottom:要素の「下側」に余白を作る
  • margin-left:要素の「左側」に余白を作る

たとえば、以下のサンプルプログラムでは、2つのボックス(段落)のうち、下のボックスにだけmargin-topを指定して、上のボックスとの間隔を広げています。このように特定の方向だけを狙って調整することで、レイアウトが崩れるのを防ぎながら、思い通りのデザインに仕上げることができます。


<style>
    .box-sample {
        border: 2px solid #333;
        background-color: #f9f9f9;
        padding: 10px;
    }
    .margin-top-only {
        /* 上側にだけ40pxの余白を作ります */
        margin-top: 40px;
        background-color: #e3f2fd;
        border: 2px solid #2196f3;
    }
</style>

<div class="box-sample">これは1つ目のボックスです。</div>
<div class="box-sample margin-top-only">
    これは2つ目のボックスです。margin-topを使って、上側にだけ広い余白を作っています。
</div>
ブラウザ表示

プログラミング未経験の方は、まず「どの方向にスペースが必要か」を考えて、該当する方向のプロパティを1つ選んで使ってみることから始めましょう。この個別指定をマスターするだけで、Webサイトのパーツ配置の自由度がぐっと高まります。

3. 4方向のマージンをまとめて指定する(ショートハンド)書き方

3. 4方向のマージンをまとめて指定する(ショートハンド)書き方
3. 4方向のマージンをまとめて指定する(ショートハンド)書き方

CSSでは、上下左右の余白(マージン)をバラバラに記述するのではなく、1行でまとめて指定する便利な書き方があります。これを「ショートハンド」と呼び、コードがスッキリして読みやすくなるため、プロの現場でも必須のテクニックです。

指定する数値の「数」によって、どの場所に余白がつくかが決まります。最初は戸惑うかもしれませんが、ルールさえ覚えれば簡単です。以下の表でルールを確認してみましょう。

値の数 適用される場所
1つ 上下左右すべてに同じ余白(例:20px)
2つ 1つ目が「上下」、2つ目が「左右」(例:20px 10px)
3つ 1つ目が「上」、2つ目が「左右」、3つ目が「下」
4つ 上・右・下・左の順(時計回り)

特に「4つの値」を指定する場合は、「時計の12時から始まって右回り」とイメージすると、未経験の方でも直感的に覚えられます。


<style>
    .box-sample {
        background-color: #f0f8ff;
        border: 2px solid #007bff;
        /* 上:10px, 右:40px, 下:80px, 左:20px (時計回り) */
        margin: 10px 40px 80px 20px;
        padding: 20px;
    }
    .container {
        background-color: #eee;
        border: 1px dashed #999;
    }
</style>

<div class="container">
    <div class="box-sample">
        時計回りにマージンを設定しています。<br>
        上が一番狭く、下が一番広い余白になっています。
    </div>
</div>
ブラウザ表示

実務では、左右を中央揃えにする際によく使う「margin: 0 auto;(上下は0、左右は自動)」という2つの値の書き方も頻繁に登場します。まずは「時計回り」の基本からマスターして、徐々に短縮形に慣れていきましょう。

4. マージンが重なってしまう「マージンの相殺」に注意

4. マージンが重なってしまう「マージンの相殺」に注意
4. マージンが重なってしまう「マージンの相殺」に注意

実は、マージンを設定するときに少しだけ注意が必要です。上下にあるボックス同士のマージンは、重なって(相殺されて)しまうことがあります。

例えば、上のボックスにmargin-bottom: 20px;、下のボックスにmargin-top: 30px;がある場合、間のすきまは20+30=50pxではなく、大きい方の30pxだけになります。


<style>
    .box1 {
        border: 2px solid blue;
        margin-bottom: 20px;
    }
    .box2 {
        border: 2px solid red;
        margin-top: 30px;
    }
</style>

<div class="box1">上のボックス</div>
<div class="box2">下のボックス</div>
ブラウザ表示

このような現象を「マージンの相殺(margin collapse)」と呼びます。もし思ったより余白が狭いと感じたら、この影響を疑ってみましょう。

5. ボックス間の余白を調整して見やすくするコツ

5. ボックス間の余白を調整して見やすくするコツ
5. ボックス間の余白を調整して見やすくするコツ

マージンを使うときは、見た目のバランスを意識することが大切です。以下のポイントを意識するときれいに整います。

  • 段落と段落の間に同じマージンを設定する
  • セクションごとに余白を多めに取る
  • 上のマージンだけでなく下のマージンも調整してバランスを取る

<style>
    .content-box {
        border: 2px solid #555;
        padding: 10px;
        margin-bottom: 20px;
    }
</style>

<div class="content-box">サービス紹介</div>
<div class="content-box">お客様の声</div>
<div class="content-box">お問い合わせ</div>
ブラウザ表示

こうすることで、ボックス間に適度な空間ができ、読みやすく整ったデザインになります。

6. 中央に配置する便利なマージン指定「margin: 0 auto」

6. 中央に配置する便利なマージン指定「margin: 0 auto」
6. 中央に配置する便利なマージン指定「margin: 0 auto」

もうひとつ便利な使い方が、margin: 0 auto;です。これは「上下の余白は0、左右の余白は自動で調整する」という意味になります。

主にボックスを画面の中央に配置したいときに使います。


<style>
    .center-box {
        width: 200px;
        border: 2px solid #0088cc;
        margin: 0 auto;
        padding: 10px;
        text-align: center;
    }
</style>

<div class="center-box">中央に配置されたボックス</div>
ブラウザ表示

このように、簡単な指定だけでボックスを中央に表示できます。ブログのタイトルやボタンの位置調整などにもよく使われます。

7. マージンを上手に使って整ったWebデザインに

7. マージンを上手に使って整ったWebデザインに
7. マージンを上手に使って整ったWebデザインに

マージンは、ただの余白ではなくデザインを整えるための重要な道具です。文章や画像の間に適度な空間を作ることで、Webページ全体が見やすくなります。

CSSのマージンを理解すれば、ボックスの間隔を自由にコントロールでき、初心者でも簡単にプロのようなレイアウトを作れるようになります。

2026年最新 スキルアップ・実践セミナー

【60分集中】Flexboxを完全攻略!最新CSS3で「崩れない・迷わない」モダンUI構築セミナー

「魅せる力」をコードで実現。CSS3でモダンWebデザインのプロトタイピングを。

本講座では、単に色を変えるだけではなく、「ユーザーを迷わせないUIデザイン」「崩れないレイアウト設計」の本質を学びます。最新のCSS3とモダンなレイアウト手法を通じて、プロの現場で通用する「美しさと機能性を両立した実装力」を最短距離で習得します。

具体的なワークショップ内容と環境

【つくるもの】
HTMLで作成した骨組みに対し、商用サイトでも採用される「スタイリッシュなカード型UI」や「レスポンシブなナビゲーション」を構築します。色の選定基準や余白(ホワイトスペース)の黄金比など、デザインの理論をコードに落とし込む工程を体験してください。

【開発環境】
フロントエンド開発の標準であるVisual Studio Code (VS Code)を継続使用。CSSの記述を効率化するプラグインや、ブラウザのデベロッパーツール(検証機能)を駆使して、リアルタイムでデザインを微調整するプロのワークフローを再現します。

この60分で得られる3つの技術資産

1. 現代のデファクトスタンダード「Flexbox」

要素の横並びや中央揃えを自由自在に操り、どんなデバイスでも崩れないレスポンシブな配置術を完全理解します。

2. メンテナンス性を高めるCSS設計の基礎

後から修正しやすい「壊れにくいコード」の書き方を伝授。プロの現場で必須となる命名規則の考え方を学びます。

3. パフォーマンスと美しさの両立

画像の最適化や軽量な装飾技法など、ページの表示速度を落とさずに高級感のある演出を行うテクニックを習得します。

※本講座は、HTMLの基礎を終えた後のステップアップ講座です。Webデザイナー、UIデザイナー、フロントエンドエンジニアへの道を切り開く「魅せる技術」を、モクモク独自のパーソナル指導で着実に定着させます。

【60分集中】Flexboxを完全攻略!最新CSS3で「崩れない・迷わない」モダンUI構築セミナー

リラックスしながら、学ぶことが大切です。しっかりと基礎を理解しましょう!

各回少人数・マンツーマン形式で徹底サポート

このセミナーの詳細・お申し込みはこちら
カテゴリの一覧へ
新着記事
New1
Bootstrap
Bootstrapカードデザイン入門!影・角丸・境界線をやさしく理解する.shadow-*と.rounded-*
New2
Bootstrap
Bootstrapのspacingスケールを最適化!$spacers編集で余白ユーティリティを自由にカスタマイズ
New3
Bootstrap
Bootstrapの$theme-colorsを拡張!ブランドカラー追加の完全ガイド【map-merge】
New4
CSS
CSS変数でカラースキームを切り替え!ダークモード対応の作り方を徹底解説
人気記事
No.1
Java&Spring記事人気No1
CSS
CSSでGoogle Fontsを使う方法を完全ガイド!初心者でもできるフォントの変更
No.2
Java&Spring記事人気No2
CSS
CSSで要素のサイズを自動調整!autoとfit-contentの使い方
No.3
Java&Spring記事人気No3
CSS
CSSの透明度を完全解説!初心者にもわかるopacityとrgbaの使い方
No.4
Java&Spring記事人気No4
HTML
HTML formタグとは?フォーム送信の基本構造を解説【初心者向け完全ガイド】
No.5
Java&Spring記事人気No5
Bootstrap
Bootstrap 5 のカラーと背景色を完全ガイド!初心者向け色の使い分け解説
No.6
Java&Spring記事人気No6
CSS
CSSの文字色と背景色をやさしく解説!初心者でもわかる基本の設定方法
No.7
Java&Spring記事人気No7
Bootstrap
Bootstrapのナビゲーションバーを固定する方法!初心者でもわかるスターターテンプレートと重なり対策
No.8
Java&Spring記事人気No8
Bootstrap
Bootstrap 3から5への一気移行ガイド!初心者でもわかる段階的リファクタリングの進め方