
vertical-alignがうまく機能しない理由を知りたい方へ

ウェブデザインやコーディングをしていると、テキストや画像の縦方向の配置で困ることってありますよね。「あ、vertical-alignで調整できるはず」と思って指定したのに、全然効かない…そんな経験、きっと多くの人が持っているんじゃないでしょうか。
実はこれ、vertical-alignプロパティの適用範囲が思っている以上に限定的だからなんですね。ブロック要素に直接指定しても効果がありませんし、単一の要素では期待通りに動作しないこともあります。この記事では、vertical-alignがどんな場面で活躍するのか、そしてなぜ効かないのかを、わかりやすく整理していきます。
最後まで読んでいただければ、vertical-alignの正しい使い方はもちろん、「こういうときはこっちを使ったほうがいい」という判断もできるようになりますよ。一緒に学んでいきましょう。
【即答ガイド】
- テーブルセルの中身を上下中央に配置したい →
vertical-align: middle;をセルに指定 - インライン要素の複数個を縦方向に揃えたい →
vertical-alignを各要素に指定 - div全体を中央に配置したい → Flexbox(
display: flex;)を使う方が簡単 - 画像とテキストの位置がずれている →
vertical-align: middle;とline-heightの調整を組み合わせる
vertical-alignプロパティの基本と全体像

まず、vertical-alignがどんなプロパティなのかを理解することが大切です。
vertical-alignというのは、CSSで指定する縦方向の配置を制御するプロパティなんですね。名前を見ると「あらゆる要素に使える」と思いがちですが、実はインライン要素、インラインブロック要素、テーブルセル要素という特定の要素にしか適用されません。
つまり、日常的に使うdivやpなどのブロック要素に直接指定しても、残念ながら効果がないんです。これが多くの初心者さんがハマるポイントなんですね。
vertical-alignの初期値はbaselineという値で、これは「親要素のベースライン(文字の下辺を基準とした線)に揃える」という意味です。テキストや画像がちょっと下がった位置に配置されるのは、この初期値が原因なんですよ。
ちなみにtext-alignというプロパティとよく混同されるんですが、こちらは横方向(左右)の配置を指定するものです。縦方向が必要な場合はvertical-alignを、横方向が必要な場合はtext-alignを使う、という感じで区別できますね。
vertical-alignを使う場面の判断基準
「では、どんなときにvertical-alignを選べばいいのか」という判断基準を整理してみましょう。以下のテーブルを参考にしてください。
| 要素の種類 | vertical-align有効? | 使用例 | おすすめの使い方 |
|---|---|---|---|
| インライン要素(<span>、<a>など) | 有効 | テキスト内の画像や小さなアイコンを揃える | 複数の要素を同時に指定 |
| テーブルセル(<td>、<th>) | 有効 | セル内のテキストやコンテンツ配置 | セルに直接指定するのが効果的 |
| display: inline-block | 有効 | インラインブロック化した要素 | 親要素のline-heightとセットで調整 |
| ブロック要素(div、p、section) | 無効 | ページレイアウト全体の配置 | Flexbox や Grid を推奨 |
この表を見ると、vertical-alignが活躍する場面って意外と限られているんですね。特にブロック要素には効かないというのが重要ポイントです。
もしあなたが「divの中身を中央に配置したい」と考えているなら、vertical-alignを使うのではなく、FlexboxやGridといった最新のレイアウト技術を使う方が、圧倒的に簡単で確実なんですよ。
vertical-alignでよくある勘違いと効かない原因
ここからは、vertical-alignを使うときにズレやすいポイント、つまりよくある勘違いについて説明していきます。
勘違い1:すべての要素に効く
一番多い勘違いが「vertical-alignはすべての要素に適用できる」という思い込みですね。実際には、ブロック要素に指定しても全く効果がありません。divやpに書いても無視されてしまうんです。
勘違い2:単一の要素でも効く
vertical-alignは「複数の要素を揃える」ためのプロパティなんです。単独の要素に指定しても、揃える対象がないので効果が限定的になってしまいます。テーブルセルなど、そもそも内容を含む要素の場合は別ですが。
勘違い3:line-heightを調整しなくていい
特にインライン要素でvertical-alignを使う場合、親要素のline-height(行の高さ)が小さいと、期待通りに配置されないことがあります。vertical-alignとline-heightは切り離せない関係なんですね。
効かないときの確認リスト
- その要素は本当にインライン要素やテーブルセルですか?(ブロック要素なら
displayを変更) - 親要素の
line-heightは適切に設定されていますか? - 複数の要素を揃えようとしていますか?(単一要素なら効果が薄い)
- テーブルセルなら、セル自体に指定していますか?(行や表に指定しても効きません)
この4つをチェックするだけで、ほとんどの「効かない問題」は解決することが多いんですよ。
vertical-alignと他の配置プロパティの使い分け
次に、vertical-alignと似た役割を持つプロパティとの違いと使い分けを見ていきましょう。
| プロパティ | 方向 | 適用範囲 | 推奨用途 | 難易度 |
|---|---|---|---|---|
| vertical-align | 縦(上下) | インライン・テーブルセル | テキストと画像の微調整 | 中 |
| text-align | 横(左右) | ブロック要素全般 | テキストや要素の水平配置 | 低 |
| Flexbox(display: flex) | 縦・横両方 | すべての要素 | 複雑なレイアウト・全体配置 | 低〜中 |
| Grid(display: grid) | 縦・横両方 | すべての要素 | 複雑なグリッドレイアウト | 中〜高 |
| margin: auto | 縦・横両方 | 絶対配置要素など | 要素の中央配置 | 低 |
この比較を見ると、最新のレイアウト手法ではFlexboxやGridが圧倒的に便利だということがわかりますね。実は、vertical-alignって「昔からあるプロパティだから知られている」というだけで、現在のウェブデザインではFlexboxの方が活躍する場面の方が多いんです。
ただし、テーブルセルのコンテンツを配置する場合や、インライン要素の微調整が必要な場合には、vertical-alignはまだまだ活躍するんですよ。つまり「正しい場面で使えば、vertical-alignは優秀なプロパティ」ということなんです。
具体的には、こんな感じで使い分けるといいですね:
- テーブルデータの上下配置 →
vertical-align - ページ全体のレイアウト →
FlexboxかGrid - テキスト内の画像やアイコン微調整 →
vertical-align - ブロック要素の中央配置 →
Flexboxかmargin: auto
vertical-align指定で失敗しやすい実例と対策
では、実際にvertical-alignで後悔しやすいケースを見ていきましょう。これらの事例から学ぶことで、あなたも同じ失敗を避けられますよ。
失敗例1:画像とテキストの配置ズレ
HTMLに以下のコードを書いたとします:
<p><img src="icon.png" alt="アイコン"> テキストです </p>
このとき、画像がテキストより若干下に位置してしまいますよね。これを直そうと、画像にvertical-align: middle;と書く人が多いんです。でも実は、これだけでは不十分なんですね。
理由は、親の<p>タグ(ブロック要素)のline-heightが影響しているからです。正しい対策は:
img { vertical-align: middle; } p { line-height: 1.5; }
こんな感じで、line-heightも合わせて調整することが大切なんです。
失敗例2:divの中身が中央に配置されない
「divの中のテキストを完全に中央に配置したい」と考えて、こんなコードを書く人も多いんですね:
div { vertical-align: middle; }
残念ながら、これは全く効きません。divはブロック要素だからです。ここは素直にFlexboxを使うべきなんですよ:
div { display: flex; align-items: center; justify-content: center; height: 200px; }
これでdiv内のすべてのコンテンツが、縦横両方で中央に配置されます。モダンなウェブデザインではこちらが推奨される方法なんです。
失敗例3:テーブルセルなのに効かない
テーブルセルにvertical-align: top;と指定しているのに、なぜか下寄せのままになっているケースがあります。これは、セルの親要素である<tr>や<table>に他のスタイルが指定されていることが原因だったりするんですね。
こういうときは、!importantを使うか、CSSの詳細度を上げることで解決することが多いです。でも根本的には、古いテーブルレイアウトを脱却して、CSSレイアウトに移行する方が長期的には良いんですよ。
失敗例4:インラインブロック要素の隙間問題
複数のdisplay: inline-block;要素を並べると、その間に思わぬ隙間が生じることがあります。これはHTML上の空白文字が原因なんですね。
vertical-alignで対策するなら、親要素にfont-size: 0;を指定して、その隙間を消すという方法があります:
div { font-size: 0; } div > span { display: inline-block; font-size: 16px; vertical-align: middle; }
ちょっとトリッキーですが、この方法を知っておくと、古いブラウザ対応の際に役立つんですよ。
vertical-align指定で最終判断:どうする?どう選ぶ?
最後に、あなたが「こんなとき、どうしたらいい?」という場面での最終判断をまとめていきますね。
【パターンA】テーブルセルのコンテンツを配置したい場合
→ vertical-alignを使うべきです。テーブルセルはvertical-alignが最も活躍する場面なんですね。
具体的には:
- 上寄せにしたい:
vertical-align: top; - 中央に配置したい:
vertical-align: middle; - 下寄せにしたい:
vertical-align: bottom;
このどれかをセルに指定するだけで、スッキリ解決しますよ。
【パターンB】インライン要素(テキスト内の画像やアイコン)を微調整したい場合
→ vertical-alignと line-heightの組み合わせが正解です。
たとえば、テキストと同じ行に配置されている画像を中央に揃えたいなら:
img { vertical-align: middle; }
ただし、親要素のline-heightが画像の高さと合致していることが大前提です。
【パターンC】ブロック要素(divやsectionなど)全体を配置したい場合
→ Flexboxを使うべきです。vertical-alignは効きませんので注意してください。
最も簡単なコードはこれです:
div { display: flex; align-items: center; justify-content: center; }
align-items: center;が縦方向、justify-content: center;が横方向の中央配置です。これだけで、ほぼすべての配置ニーズに対応できます。
【パターンD】古いブラウザ対応が必要な場合
→ vertical-alignと display: inline-block の組み合わせが便利です。
IE11や古いブラウザではFlexboxの対応が不完全な場合があるんですね。そういうときは、inline-blockとvertical-alignの組み合わせが活躍します:
div { font-size: 0; } .box { display: inline-block; font-size: 16px; vertical-align: middle; width: 30%; }
ちょっと手間がかかりますが、互換性が必要な場合は検討してみてください。
【パターンE】何を選べばいいか迷う場合
→ Flexboxをデフォルトに考えるというのが、現代的なアプローチです。
2024年時点で、主要なブラウザはすべてFlexboxに対応しています。古いブラウザ対応が明確に必要でない限り、Flexboxを最初の選択肢として検討する方が、あとあとのメンテナンスも楽になるんですよ。
vertical-alignは「テーブルセルとインライン要素専用のプロパティ」として割り切って、他の用途ではFlexboxやGridを使う。この判断基準を持つことで、コーディングがぐっと楽になるはずです。
【最終的なチェックリスト】
- テーブルセルの中身を配置する → vertical-align
- インライン要素を微調整する → vertical-align + line-height
- ブロック要素を配置する → Flexbox推奨
- 複雑なグリッドレイアウト → Grid推奨
- 迷ったときはFlexbox → 最も汎用的で効率的
このリストを頭に入れておくだけで、「あ、これはvertical-alignじゃなくてFlexboxだな」という判断が、素早くできるようになりますよ。
終わりに
vertical-alignについて、基本から応用まで一緒に学んできましたね。このプロパティって「なんか難しい」という印象を持つ人が多いんですが、実は適用範囲が限定的だからこそ、その場面での役割は明確なんです。
テーブルセルとインライン要素。この2つの場面でしか使えないというのは、逆に言えば「この2つなら絶対にvertical-alignで解決できる」ということなんですね。
そしてそれ以外の配置については、FlexboxやGridといった最新技術が圧倒的に便利です。あなたがこれからコーディングするときは、まずは「このレイアウトはどのプロパティが適切か」を判断することから始めてください。その判断ができれば、CSSでの配置問題はほぼ完全に解決するんですよ。
vertical-alignと上手に付き合いながら、素敵なウェブデザインを作っていってくださいね。応援しています。