html5 marginとpaddingで余白を設定する

htmlで余白の設定をするときは、marginpaddingのスタイルを使用します。

例えば、以下のように色を分けて表示しても、要素どうしがくっついてしまい、わかりづらくなってしまいますので、余白を設定します。

<div style="background-color:red; border:solid 3px blue;">
  <span style="background-color:orange;">トマト</span>は赤い
</div>
<div style="background-color:green; border:solid 3px blue;">
  <span style="background-color:orange;">ピーマン</span>は緑
</div>

margin

要素と要素の間の余白を設定する場合はmarginを使用します。以下のように指定すると要素と要素の間の上下左右の余白が10pxできることになります。

style="margin:10px;"

部分的に設定する

html5 ボーダーのスタイルで罫線を表示するで紹介したボーダーの指定方法と同じように、-top-bottom-left-rightをつけると指定した部分のみにスタイルを反映することができます。

例えば、margin-top: 5px;とすると、上部分のみに5pxの余白ができます。

スペースで区切って指定する

こちらもボーダーと同じように値をスペースで区切ることにより、上下左右のスタイルを指定できます。上下左右に反映されるスタイルは基本的に同じように指定することができます。

margin:10px;のように、1つだけ値を指定した場合は、上下左右がそのスタイルになります。

margin:10px 5px;のように、2つ値を指定した場合は、1つ目が上下、2つ目が左右のスタイルになります。

margin:10px 5px 15px;のように、3つ値を指定した場合は、1つ目が、2つ目が左右、3つ目がのスタイルになります。

margin:10p 5px 15px 20px;のように、4つ値を指定した場合は、1つ目が、2つ目が、3つ目が、4つ目がのスタイルになります。

divのブロック要素に対してmarginのスタイルを適用します。

<div style="margin:20px; background-color:red; border:solid 3px blue;">
  <span style="background-color:orange;">トマト</span>は赤い
</div>
<div style="margin:20px; background-color:green; border:solid 3px blue;">
  <span style="background-color:orange;">ピーマン</span>は緑
</div>

ネガティブマージン

marginの値にマイナス値も設定することができます。マイナス値を設定したmarginをネガティブマージンと呼ぶことが多いです。複雑なレイアウトで位置を微調整したい場合や、要素を重ねたい場合などに使用します。 うまく使いこなせれば、凝ったレイアウトを作ることができますが、多用し過ぎるとレイアウトがわかりづらくなってしまいますので注意が必要です。

padding

marginが要素の外側の余白を設定するのに対して、paddingは要素の内側の余白を設定します。

「内側」という表現はわかりづらいかもしれませんが、ボーダーより内側のことを指します。

実際にpaddingを指定すると以下のようになります。

<div style="padding:20px; margin:20px; background-color:red; border:solid 3px blue;">
  <span style="background-color:orange;">トマト</span>は赤い
</div>
<div style="padding:20px; margin:20px; background-color:green; border:solid 3px blue;">
  <span style="background-color:orange;">ピーマン</span>は緑
</div>

paddingmarginとは異なり、マイナス値を指定できません。

ボーダーや背景色を指定しない場合は、marginでもpaddingでも見た目は変わりませんが、目的に合わせて使い分けていきましょう。

インライン要素の余白

上記の例ではすべてブロック要素に対して余白を設定していましたが、インライン要素に対しても余白を設定することができます。

ただし、marginの上下は設定することができません。

<div style="padding:20px; margin:20px; background-color:red; border:solid 3px blue;">
  <span style="padding:20px; margin:20px; background-color:orange;">トマト</span>は赤い
</div>
<div style="padding:20px; margin:20px; background-color:green; border:solid 3px blue;">
  <span style="padding:20px; margin:20px; background-color:orange;">ピーマン</span>は緑
</div>

関連記事

  • html5 classを使って同じstyleをまとめる

    スタイルを各要素の中にたくさん書くとわかりづらくなってしまいます。以下のように、同じスタイルを複数の箇所に記載しているときは、classを使えば同じスタイルを1箇所にまとめることができます。クラスはh...


  • html5 ブロック要素とインライン要素を理解する

    htmlの要素には大きく分けてブロック要素とインライン要素があります。今回はこの2つの要素の違いについて説明します。例えば以下のhtmlで、トマトについての説明の箇所の背景色を赤、ピーマンについての説...


  • html5 ボーダーのスタイルで罫線を表示する

    pタグとh1タグの段落と見出しで読みやすい文章構成を作成する方法は段落と見出しを表示して、見た目をわかりやすくしました。今回は罫線を引いて、より見た目をわかりやすくする方法を紹介します。文字色を変える...


  • pタグとh1タグの段落と見出しで読みやすい文章構成を作成する方法

    前回ホームページ入門・初心者向け html5の基本的な文法までで、htmlをブラウザで表示することができるようになりました。今回からは、実際にhtmlでのいろいろな表現方法を紹介していき、最終的にはき...


  • ホームページ入門・初心者向け html5の基本的な文法

    前回初めてのホームページ作成のためのhtmlの基本でホームページの作成にあたって、「htmlとは何か?」ということを説明しました。今回は、実際にhtmlをどのように書いていくのか説明します。※この記事...


  • 初めてのホームページ作成のためのhtmlの基本

    プログラミングの経験もなく、初めてホームページを作成しようと考えている人に向けて、htmlの基本を数回に分けて説明します。予備知識としてホームページの基本的な仕組みと考え方でホームページの基本的な仕組...


  • cssで三角形を表示する方法

    画像を使わずに、cssでスタイルを指定するだけで三角形を表示させる方法を紹介します。三角形を表示させるにはborder(枠線)を使用します。なぜborderで三角形を作れるのか、まずはその説明をします...


  • cssだけでホバー時にバルーンポップアップを表示させる

    javascriptを使わず、cssだけでマウスホバー時に、バルーンポップアップを表示させる方法を紹介します。完成形は以下のようなイメージです。最初に完成形のcssを記載します。cssはjavascr...


  • canvasでグラデーションを表現する

    canvasのアニメーションで軌跡・残像・フェードアウトを表現するまではいろいろな図形を描画したり、描画した図形を動かしてアニメーションを表現する方法を紹介しました。今回は単色だけでなく、グラデーショ...


  • canvasのアニメーションで軌跡・残像・フェードアウトを表現する

    前回canvasのアニメーションの基本的な考え方でcanvasで簡単なアニメーションを表現する方法を紹介しました。今回はアニメーションを応用し軌跡や残像を残したり。フェードアウトする方法を紹介します。...