CSSグリッドにおける行の結合
グリッド内の行と列はグリッドを形成します。 要素がグリッドセルの1つではなく、複数を占有するようにすることができます。
要素が複数の行を占有するようにするには、
プロパティgrid-rowを設定する必要があります。
このプロパティでは、スラッシュで区切って、
グリッド内の要素の開始位置と終了位置を示す数値を指定します。
これにより、要素は最初の位置から2番目の位置まで
(2番目の位置は含まずに)拡張されます。つまり、
値1 / 2は要素に最初のセルを1つ占有させ、
値1 / 3は要素に1番目と2番目のセルを占有させます
(ただし3番目は含みません)。
例
3つの子要素を持つグリッドがあるとします。 最初の要素が2行を占有するように配置してみましょう:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
</div>
#parent {
display: grid;
grid-template-columns: 2fr 1fr;
height: 300px;
width: 400px;
padding: 10px;
border: 2px solid #696989;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 3; /* 2行 */
}
#elem2 {
grid-row: 1 / 2;
}
#elem3 {
grid-row: 2 / 3;
}
:
例
次に、4番目のブロックに3行を割り当ててみましょう:
<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: 2fr 1fr;
height: 300px;
width: 400px;
padding: 10px;
border: 2px solid #696989;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
grid-row: 1 / 2;
}
#elem2 {
grid-row: 2 / 3;
}
#elem3 {
grid-row: 3 / 4;
}
#elem4 {
grid-row: 1 / 4;
}
:
実践タスク
以下の例に従ってすべての要素を配置し、行の結合を実行してください:
以下の例に従ってすべての要素を配置し、行の結合を実行してください:
以下の例に従ってすべての要素を配置し、行の結合を実行してください: