Implicit gridok a CSS-ben
Implicit grid jön létre automatikusan a böngészőben, amikor az elemek száma nem fér el az explicit gridben. Nézzük meg, hogyan történik ez.
Tegyük fel, hogy van négy blokkunk:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem3">4</div>
</div>
Tegyük fel, hogy gridünk mérete
3 x 3:
#parent {
display: grid;
grid-template-columns: 50px 50px 50px;
grid-template-rows: 50px 50px 50px;
}
Helyezzük el három blokkunkat a gridben:
#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;
}
A negyedik blokkot pedig helyezzük el a negyedik sorban és oszlopban:
#elem4 {
grid-row: 4 / 5;
grid-column: 4 / 5;
}
Mivel gridünk mérete
3 x 3, ezért ilyen
negyedik sor és oszlop nem lesz ebben a
gridben. De nem lesz explicit formában,
vagyis a általunk megadottban. Viszont a böngésző
implicit módon, vagyis önállóan létrehozza azokat.
Eközben, mivel a méreteket csak az explicit gridre adtuk meg, így a griden kívüli cellák méreteit a böngésző számítja ki. Vagyis esetünkben a negyedik blokk méreteit a böngésző automatikusan beállítja.
Nézzük meg, mit kapunk:
<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;
}
:
Tegyük fel, hogy gridjében 6 blokk van.
Helyezzen el 3 blokkot az explicit
gridben, és három blokkot az implicit gridben.