--- title: グリッドラッパー slug: Web/CSS/Layout_cookbook/Grid_wrapper tags: - CSS - Guide - Layout - cookbook - recipes translation_of: Web/CSS/Layout_cookbook/Grid_wrapper ---
このパターンは、中央のラッパー内でグリッドのコンテンツを整列させるのに便利ですが、必要に応じて項目を脱出させて親要素やページの端に整列させることもできます。
グリッド上に配置された項目は、水平方向の中央に配置された最大幅のラッパーやグリッドの外側の端に揃えることができます。
{{EmbedGHLiveSample("css-examples/css-cookbook/grid-wrapper.html", '100%', 720)}}
このレシピでは、CSS グリッドの {{cssxref("minmax")}} 関数を使用して、{{cssxref("grid-template-columns")}} プロパティでグリッドトラックのサイズを定義しています。 最大幅を持つ中央の(グリッドレイアウトに使う6つの)列には、0 以上の最小値と、列トラックが大きくなれる最大サイズを指定する最大値を設定できます。 数値の単位(ピクセル、em、rem)を使用すると、中央のラッパーの固定最大サイズが作成されますが、パーセント値またはビューポート単位を使用すると、このラッパーはそのコンテキストに応じて拡大または縮小します。
外側の2つの列の最大サイズは 1fr
です。 つまり、グリッドコンテナ内の残りの使用可能スペースを埋めるようにそれぞれが拡大されます。
このレシピをページレベルで使用するときは、コンテンツを水平方向に中央揃えするために、次のように左右の auto
の {{cssxref("margin")}} とともに max-width
を設定すると便利です。
.grid { max-width: 1200px; margin: 0 auto; // コンテナを水平方向に中央揃え } /* ブラウザーがグリッドをサポートしている場合は、max-width と margin を取り除く */ @supports (display: grid) { .grid { display: grid; /* 他のグリッドのコードはここへ */ max-width: none; margin: 0; } }
full-width
項目をビューポートの端まで「脱出」させるには、次のトリックを使用できます(Una Kravets の好意による)。
.item { width: 100vw; margin-left: 50%; transform: translate3d(-50%, 0, 0); }
これは、正確なグリッド上で項目を簡単に整列させることができるという利点が必要ない場合に限り、レイアウトの適切な近似値を提供します。
グリッドを使用すると(理由の範囲内で)項目を適切な場所に配置できますが、CSS グリッドを使用して項目を配置する場合は、基になるマークアップが論理的な順序に従うことが重要です(詳細については、CSS グリッドのレイアウトとアクセシビリティを参照)。
さまざまなレイアウト方法が異なるブラウザーサポートを持っています。 使用されているプロパティの基本的なサポートの詳細については、以下の表を参照してください。
The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.
{{Compat("css.properties.grid-template-columns")}}