CSSにおける暗黙的グリッド
暗黙的グリッドは、要素の数が明示的なグリッドに収まらない場合にブラウザが自動的に作成します。 これがどのように行われるか見てみましょう。
4つのブロックがあるとします:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
グリッドのサイズを
3 x 3 とします:
#parent {
display: grid;
grid-template-columns: 50px 50px 50px;
grid-template-rows: 50px 50px 50px;
}
最初の3つのブロックを グリッド上に配置します:
#elem1 {
grid-row: 1 / 2;
grid-column: 1 / 2;
}
#elem2 {
grid-row: 2 / 3;
grid-column: 2 / 3;
}
#elem3 {
grid-row: 3 / 4;
grid-column: 3 / 4;
}
4つ目のブロックを 4行目、4列目に配置します:
#elem4 {
grid-row: 4 / 5;
grid-column: 4 / 5;
}
私たちのグリッドはサイズが
3 x 3なので、そのような
4行目や4列目はこのグリッドには存在しません。
しかし、それは明示的な形、つまり私たちが定義した形では存在しません。
しかしブラウザはそれらを暗黙的に、つまり自動的に作成します。
その際、サイズを指定したのは明示的グリッドのみなので、 このグリッドの外側にあるセルのサイズはブラウザによって計算されます。 つまり、私たちのケースでは4つ目のブロックのサイズは ブラウザによって自動的に設定されます。
結果を見てみましょう:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem4">4</div>
</div>
#parent {
display: grid;
grid-template-columns: 50px 50px 50px;
grid-template-rows: 50px 50px 50px;
border: 2px solid #696989;
padding: 10px;
width: 400px;
height: 400px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 2;
grid-column: 1 / 2;
}
#elem2 {
grid-row: 2 / 3;
grid-column: 2 / 3;
}
#elem3 {
grid-row: 3 / 4;
grid-column: 3 / 4;
}
#elem4 {
grid-row: 4 / 5;
grid-column: 4 / 5;
}
:
あなたのグリッドに6つのブロックがあるとします。
3つのブロックを明示的グリッドに配置し、
残りの3つのブロックを暗黙的グリッドに配置してください。