CSS Grid vs Flexbox:2026年のWebレイアウト完全ガイド

CSS Grid vs Flexbox:2026年のWebレイアウト完全ガイド

CSS GridとFlexboxの使い分けは?違い、用途、効果的な組み合わせ方を実践コード例で解説。

2026年3月17日4分で読了

CSS GridとFlexboxを完全に使いこなす

「GridとFlexbox、どっちを使えばいいの?」これはフロントエンド開発者なら誰もが抱く疑問です。2026年現在、両方とも全ブラウザで完全サポートされており、モダンCSSレイアウトの主役として活躍しています。

結論から言えば、どちらかを選ぶのではなく、両方を使い分けることが正解です。それぞれが得意とする場面が異なるからです。

根本的な違い:1次元 vs 2次元

Flexbox:1次元レイアウト

Flexboxは**1方向(横または縦)**の並べ方を制御します。

.container {
  display: flex;
  flex-direction: row;  /* または column */
  justify-content: space-between;
  align-items: center;
}

ナビゲーションバー、ボタングループ、カードの並列表示など、一列に要素を並べる場合に最適です。

CSS Grid:2次元レイアウト

CSS Gridは行と列の両方を同時に制御します。

.container {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  grid-template-rows: auto;
  gap: 1rem;
}

ダッシュボード、ギャラリー、複雑なページレイアウトなど、縦横の両方向に要素を配置する場合に最適です。

Flexboxの実践例

ナビゲーションバー

<nav class="navbar">
  <div class="logo">ToolBox Hub</div>
  <ul class="nav-links">
    <li><a href="/tools">ツール</a></li>
    <li><a href="/blog">ブログ</a></li>
    <li><a href="/docs">ドキュメント</a></li>
  </ul>
  <button class="cta-button">無料で始める</button>
</nav>
.navbar {
  display: flex;
  justify-content: space-between;  /* ロゴ・リンク・ボタンを均等配置 */
  align-items: center;             /* 縦方向の中央揃え */
  padding: 1rem 2rem;
  background: #1a1a2e;
}

.nav-links {
  display: flex;
  gap: 2rem;
  list-style: none;
  margin: 0;
  padding: 0;
}

.cta-button {
  background: #6c63ff;
  color: white;
  padding: 0.5rem 1.5rem;
  border-radius: 8px;
  border: none;
  cursor: pointer;
}

カードのレイアウト

/* ツールカードを横並びに表示 */
.tool-list {
  display: flex;
  flex-wrap: wrap;  /* 画面幅に合わせて折り返す */
  gap: 1.5rem;
}

.tool-card {
  flex: 1 1 280px;  /* 最小幅280px、均等に伸縮 */
  padding: 1.5rem;
  border-radius: 12px;
  background: white;
  box-shadow: 0 2px 8px rgba(0,0,0,0.1);
}

センタリング(最もよく使う用途の一つ)

/* 要素を完全に中央揃えにする */
.hero-section {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  min-height: 100vh;
  text-align: center;
}

/* アイコンとテキストを横並びに */
.feature-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

CSS Gridの実践例

ダッシュボードレイアウト

<div class="dashboard">
  <header class="header">ヘッダー</header>
  <nav class="sidebar">サイドバー</nav>
  <main class="main-content">メインコンテンツ</main>
  <aside class="widgets">ウィジェット</aside>
  <footer class="footer">フッター</footer>
</div>
.dashboard {
  display: grid;
  grid-template-areas:
    "header  header  header"
    "sidebar main    widgets"
    "footer  footer  footer";
  grid-template-columns: 240px 1fr 300px;
  grid-template-rows: 60px 1fr 60px;
  min-height: 100vh;
  gap: 1rem;
}

.header  { grid-area: header; }
.sidebar { grid-area: sidebar; }
.main-content { grid-area: main; }
.widgets { grid-area: widgets; }
.footer  { grid-area: footer; }

写真ギャラリー

/* レスポンシブな写真ギャラリー */
.gallery {
  display: grid;
  /* 最小200px、利用可能スペースを自動で埋める */
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
}

.gallery-item {
  aspect-ratio: 1;  /* 正方形を保持 */
  overflow: hidden;
  border-radius: 8px;
}

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.3s ease;
}

.gallery-item:hover img {
  transform: scale(1.05);
}

記事レイアウト(Holy Grail)

/* 古典的なHoly Grailレイアウト */
.page-layout {
  display: grid;
  grid-template-columns: 200px 1fr 200px;
  grid-template-rows: auto 1fr auto;
  min-height: 100vh;
}

/* スパンで複数セルを占有 */
.full-width {
  grid-column: 1 / -1;  /* 全列にまたがる */
}

GridとFlexboxの使い分け表

場面推奨理由
ナビゲーションバーFlexbox一列の要素を並べるだけ
ページ全体のレイアウトGridヘッダー・サイドバー・フッターの2D配置
ボタングループFlexbox横一列のシンプルな並び
カードグリッドGrid整列した行と列が必要
センタリングFlexboxシンプルで直感的
フォームレイアウトGridラベルと入力フィールドの整列
ヒーローセクションFlexboxコンテンツの縦横中央揃え
ダッシュボードGrid複雑な2Dレイアウト
チャットUIFlexboxメッセージを縦方向に並べる
写真ギャラリーGrid均等なグリッド表示

両方を組み合わせる

実際のプロジェクトでは、GridとFlexboxを組み合わせて使います。

/* Gridでページ全体の構造を作り... */
.app {
  display: grid;
  grid-template-columns: 260px 1fr;
  grid-template-rows: 64px 1fr;
  height: 100vh;
}

/* 各セクション内でFlexboxを使う */
.header {
  grid-column: 1 / -1;
  display: flex;                    /* ← Flexboxで内部要素を配置 */
  align-items: center;
  justify-content: space-between;
  padding: 0 2rem;
  border-bottom: 1px solid #e5e7eb;
}

.sidebar {
  display: flex;
  flex-direction: column;           /* ← メニュー項目を縦並びに */
  padding: 1rem;
  border-right: 1px solid #e5e7eb;
}

/* カードグリッドは再びGridで */
.cards-container {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 1.5rem;
  padding: 2rem;
  align-content: start;
}

レスポンシブデザインパターン

Grid でのレスポンシブ対応

/* モバイルファースト */
.features-grid {
  display: grid;
  grid-template-columns: 1fr;  /* スマホ:1列 */
  gap: 1.5rem;
}

@media (min-width: 768px) {
  .features-grid {
    grid-template-columns: repeat(2, 1fr);  /* タブレット:2列 */
  }
}

@media (min-width: 1024px) {
  .features-grid {
    grid-template-columns: repeat(3, 1fr);  /* デスクトップ:3列 */
  }
}

/* auto-fill を使えばメディアクエリなしでレスポンシブに */
.auto-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(280px, 100%), 1fr));
  gap: 1.5rem;
}

Flexbox でのレスポンシブ対応

.card-list {
  display: flex;
  flex-wrap: wrap;
  gap: 1.5rem;
}

.card {
  /* モバイルは100%幅、それ以上では均等に */
  flex: 1 1 min(100%, 280px);
}

よくある間違いと解決法

Gridの高さが揃わない

/* NG: カードの高さがバラバラになる */
.card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}

/* OK: align-items で制御 */
.card-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  align-items: start;  /* または stretch(デフォルト) */
}

Flexboxで最後の行が左揃えにならない

/* NG: flex-wrap使用時に最後の行が中央/均等になってしまう */
.items {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

/* OK: Gridのauto-fillを使う(より簡単な解決策) */
.items {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 1rem;
}

まとめ

GridとFlexboxは競合ツールではなく、相互補完的なツールです。

  • Flexbox: 一次元(行または列)の並び。ナビ、ボタン、センタリングに◎
  • Grid: 二次元(行と列)の配置。ページレイアウト、ダッシュボード、ギャラリーに◎
  • 組み合わせ: Gridで骨格を作り、Flexboxで細部を整える

「どちらを使うか」を考えるのではなく、「この要素は1方向に並べるのか、それとも縦横両方に配置するのか」を考えると、自然と正しい選択ができるようになります。両方を実際にコーディングして使ってみることが、マスターへの一番の近道です。

関連記事