Няяўныя грідзы ў CSS
Няяўны грід ствараецца браўзерам аўтаматычна, калі колькасць элементаў не змяшчаецца ў явную сетку. Давайце паглядзім, як гэта адбываецца.
Хай у нас ёсць чатыры блока:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
<div id="elem3">4</div>
</div>
Хай наша сетка мае памеры
3 на 3:
#parent {
display: grid;
grid-template-columns: 50px 50px 50px;
grid-template-rows: 50px 50px 50px;
}
Размясцім тры нашых блока па сетцы:
#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;
}
Так як наша сетка памерам
3 на 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: 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 блока ў явной
сетцы, а тры блока ў няяўной.