CSS

The CSS display property is a fundamental setting that determines how HTML elements are arranged and displayed on a page.

display

CSSのdisplayプロパティは、HTML要素の表示形式を決定する非常に重要なプロパティです。要素の配置、振る舞い、さらにはレイアウト全体に大きな影響を与えるため、正しく理解することで、より柔軟で効率的なデザインが可能になります。

displayプロパティの基本

displayとは?

displayは、HTML要素がどのように「表示」されるかを制御します。

ブラウザは各要素に対して、デフォルトのdisplay値を持っています。例えば、<div>は通常block<span>は通常inlineです。

このプロパティを利用することで、要素のレイアウトの仕方や、コンテンツの流れを柔軟に調整できます。

基本的な値

block
説明
要素が新しい行から始まり、横幅は親要素いっぱいに広がります。
利用例
<div>, <h1>など
コード例

HTML

<div class="block-sample">これはブロック要素です。</div>

CSS

.block-sample {
	display: block;
	background-color: #f0f0f0;
	padding: 10px;
	margin-bottom: 10px;
}
これはブロック要素です。
inline
説明
要素がテキストの流れの中に配置され、幅や高さの指定は基本的に無視されます。
利用例
<span>, <a>など
コード例

HTML

<p>
	この文章の中に<span class="inline-sample">インライン要素</span>が入っています。
</p>

CSS

.inline-sample {
	display: inline;
	background-color: palegreen;
	padding: 5px;
}

この文章の中にインライン要素が入っています。

inline-block
説明
インライン要素の特性とブロック要素の特性を併せ持ち、要素は横に並びながらも幅や高さの指定が可能です。
利用例
ナビゲーションメニューやボタン群など
コード例

HTML

<div class="inline-block-sample">ボタン1</div>
<div class="inline-block-sample">ボタン2</div>

CSS

.inline-block-sample {
	display: inline-block;
	width: 150px;
	height: 50px;
	background-color: palegreen;
	text-align: center;
	line-height: 50px;
	margin-right: 5px;
}
ボタン1
ボタン2
none
説明
要素を完全に非表示にします。レイアウト上からも除外されるため、スペースも占有しません。
利用例
JavaScriptでの動的表示切替や、レスポンシブデザインでの条件分岐に利用
コード例

HTML

<div>常に表示される要素</div>
<div class="hidden">この要素は非表示です</div>

CSS

.hidden {
	display: none;
}
常に表示される要素

最新のレイアウト技法とdisplayプロパティ

現代のWebデザインでは、単なるblockinlineだけでなく、より複雑なレイアウトを簡単に実現できるプロパティも登場しています。

Flexbox

概要

flexbox(柔軟なボックスレイアウト)は、一方向または複数方向に並ぶ要素の配置や並び順を簡単に制御できる手法です。

主軸(main axis)と交差軸(cross axis)の概念により、アイテムの整列や分布、余白の調整が容易になります。

主なプロパティ
display: flex;
コンテナに設定することで、内部の子要素がフレックスアイテムとして扱われます。
flex-direction
アイテムの並び順(rowcolumnrow-reversecolumn-reverse)を設定。
justify-content
主軸に沿ったアイテムの配置(flex-startflex-endcenterspace-betweenspace-around)。
align-items
交差軸に沿った整列(flex-startflex-endcenterbaselinestretch)。
flex-wrap
アイテムの折り返し(nowrapwrapwrap-reverse)を指定。
サンプルコード

HTML

<div class="flex-container">
	<div class="flex-item">アイテム1</div>
	<div class="flex-item">アイテム2</div>
	<div class="flex-item">アイテム3</div>
</div>

CSS

.flex-container {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
	background-color: palegreen;
	padding: 10px;
}
.flex-item {
	background-color: darkgreen;
	padding: 15px;
	margin: 5px;
}
アイテム1
アイテム2
アイテム3

Gridレイアウト

概要

gridレイアウトは、二次元のグリッドを利用して要素を配置する方法で、複雑なレイアウトもシンプルなコードで実現できます。

行(row)と列(column)に分割し、各要素の位置や大きさを正確に制御できます。

主なプロパティ
display: grid;
コンテナに設定し、内部要素をグリッドアイテムに変換します。
grid-template-columns / grid-template-rows
グリッドの列と行の構成を定義します。例えば、repeat(3, 1fr)は3等分することを意味します。
grid-gap(またはgap
グリッドアイテム間の隙間を設定します。
grid-area
グリッド内でのアイテムの配置を指定します。
サンプルコード

HTML

<div class="grid-container">
	<div class="grid-item">グリッド1</div>
	<div class="grid-item">グリッド2</div>
	<div class="grid-item">グリッド3</div>
	<div class="grid-item">グリッド4</div>
	<div class="grid-item">グリッド5</div>
	<div class="grid-item">グリッド6</div>
</div>

CSS

.grid-container {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	grid-gap: 10px;
	background-color: #f3e5f5;
	padding: 10px;
}
.grid-item {
	background-color: #ce93d8;
	padding: 20px;
	text-align: center;
}
グリッド1
グリッド2
グリッド3
グリッド4
グリッド5
グリッド6

displayプロパティの応用と注意点

表形式のレイアウト

display: table; display: table-row; display: table-cell;
CSSで表形式のレイアウトを実現する方法です。これは、HTMLの<table>タグを使わずに、データの並びやレイアウトを表形式で表現したい場合に有用です。
注意
この方法は、厳密な表データの意味合いではなく、レイアウト目的で利用するため、アクセシビリティ面などを考慮する必要があります。

互換性とブラウザサポート

現在、ほとんどのモダンブラウザはflexboxやgridの仕様をサポートしていますが、古いブラウザ(特にIE)では一部サポートが不十分な場合があります。

レスポンシブデザインやアクセシビリティを考える際には、フォールバック(代替手法)も検討しましょう。

displayvisibilityの違い

display: none; は要素自体をレイアウトから除外するのに対し、visibility: hidden; は要素を非表示にするが、レイアウト上はスペースを保持するという違いがあります。用途に応じて使い分けることが重要です。

コンテキスト依存のdisplay値

一部の要素は、コンテキストによってデフォルトのdisplay値が変わる場合があります。例えば、フォームの要素やリストの項目は、各自の意味合いに応じた表示がなされます。

独自のカスタムコンポーネントを作成する際は、適切なdisplay値を指定して、意図したレイアウトが実現できるかテストすることが大切です。

実践的なTipsと高度なテクニック

動的なレイアウトの切り替え

JavaScriptを活用して、ユーザーの操作に応じてdisplay値を変更することで、タブの切り替えやモーダルウィンドウの表示・非表示など、動的なインタラクションが実現できます。

HTML

<script>
	<!-- JavaScript code here -->
</script>
<button onclick="toggleVisibility('toggleDiv')">表示/非表示切替</button>
<div id="toggleDiv" style="display: block; background: palegreen; padding: 10px;">
	この要素はボタンで表示/非表示が切り替わります。
</div>

JavaScript

function toggleVisibility(id) {
	const element = document.getElementById(id);
	element.style.display = (element.style.display === 'none') ? 'block' : 'none';
}
この要素はボタンで表示/非表示が切り替わります。

レスポンシブデザインとの組み合わせ

メディアクエリと組み合わせることで、画面サイズに応じてdisplay値を変更し、最適なレイアウトを実現することが可能です。

CSS

@media (max-width: 600px) {
	.sidebar {
		display: none; /* 小さい画面ではサイドバーを非表示にする */
	}
}

アニメーションとの連携

CSSのtransitionanimationプロパティと組み合わせると、displayそのものではなく、要素の出現方法(フェードイン・フェードアウトなど)を自然な形で表現することができます。

※ただし、displayプロパティはアニメーション対象にできないため、opacitytransformを併用する工夫が必要です。

デバッグと検証

ブラウザのデベロッパーツールを活用して、各要素のdisplayプロパティやレイアウトの構造を確認しましょう。

特に、flexboxやgridレイアウトはビジュアルツールで確認できるため、問題解決やデザインの微調整に非常に役立ちます。

まとめ

CSSのdisplayプロパティは、Webデザインにおけるレイアウト制御の要です。

このコンテンツを通して、CSSのdisplayプロパティの基本から応用まで幅広く理解でき、Webページのデザイン力向上に役立てていただければ幸いです。