Niejawne siatki w CSS
Niejawna siatka jest tworzona automatycznie przez przeglądarkę, gdy liczba elementów nie mieści się w jawnej siatce. Przyjrzyjmy się, jak to się dzieje.
Załóżmy, że mamy cztery bloki:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem3">4</div>
</div>
Załóżmy, że nasza siatka ma wymiary
3 na 3:
#parent {
display: grid;
grid-template-columns: 50px 50px 50px;
grid-template-rows: 50px 50px 50px;
}
Umieśćmy trzy nasze bloki w siatce:
#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 czwarty blok umieścimy w czwartym wierszu i kolumnie:
#elem4 {
grid-row: 4 / 5;
grid-column: 4 / 5;
}
Ponieważ nasza siatka ma wymiary
3 na 3, to takiego
czwartego wiersza i kolumny w tej
siatce nie będzie. Ale nie będzie ich w jawny sposób,
czyli w przez nas zdefiniowanej. Jednak przeglądarka
utworzy je niejawnie, czyli samodzielnie.
Jednocześnie, ponieważ wymiary podaliśmy tylko dla jawnej siatki, to dla komórek poza tą siatką wymiary zostaną obliczone przez przeglądarkę. Czyli w naszym przypadku wymiary czwartego bloku zostaną ustawione automatycznie przez przeglądarkę.
Zobaczmy, co otrzymamy:
<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;
}
:
Załóżmy, że w twojej siatce jest 6 bloków.
Umieść 3 bloki w jawnej
siatce, a trzy bloki w niejawnej.