Implicitné gridy v CSS
Implicitný grid je vytvorený prehliadačom automaticky, keď sa počet prvkov nezmestí do explicitnej mriežky. Pozrime sa, ako k tomu dochádza.
Majme štyri bloky:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem3">4</div>
</div>
Nech naša mriežka má rozmery
3 na 3:
#parent {
display: grid;
grid-template-columns: 50px 50px 50px;
grid-template-rows: 50px 50px 50px;
}
Umiestnime tri naše bloky do mriežky:
#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 štvrtý blok umiestnime vo štvrtom riadku a stĺpci:
#elem4 {
grid-row: 4 / 5;
grid-column: 4 / 5;
}
Keďže naša mriežka má rozmery
3 na 3, tak takýto
štvrtý riadok a stĺpec v tejto
mriežke nebude. Ale nebudú v explicitnej podobe,
teda v nami zadanej. Ale prehliadač
ich vytvorí implicitne, teda sám.
Pričom, keďže rozmery sme uviedli len pre explicitnú mriežku, tak pre bunky mimo tejto mriežky rozmery budú vypočítané prehliadačom. Teda v našom prípade rozmery štvrtého bloku budú nastavené prehliadačom automaticky.
Pozrime sa, čo nám z toho vznikne:
<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;
}
:
Nech vo vašej mriežke je 6 blokov.
Umiestnite 3 blokov do explicitnej
mriežky a tri bloky do implicitnej.