Preklapanje elemenata CSS Grida
Sistem mreže (grid) obezbeđuje mogućnost
preklapanja nekih elemenata preko drugih kada se
oblasti mreže preklapaju ili kada su navedeni
negativni spoljni margini.
Preklapanje se može dogoditi podrazumevano,
ali takođe za svaki element može se postaviti određeni redosled
putem svojstava z-index i order,
kao i njihove kombinacije.
Podrazumevano preklapanje elemenata u grid-u
Pretpostavimo da imamo tabelu u kojoj se elementi preklapaju jedni preko drugih:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
</div>
#parent {
display: grid;
grid: repeat(6, 1fr) / repeat(6, 1fr);
border: 2px solid #696989;
padding: 10px;
width: 400px;
height: 300px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
background-color: pink;
grid-column: 1 / 4;
grid-row: 1 / 5;
}
#elem2 {
background-color: orange;
grid-column: 2 / 5;
grid-row: 3 / 6;
}
#elem3 {
background-color: green;
grid-column: 3 / 6;
grid-row: 2 / 4;
}
:
Promena redosleda preklapanja elemenata pomoću svojstva order
Sada primenimo svojstvo order,
postavljajući ga u svakom podređenom elementu:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
</div>
#parent {
display: grid;
grid: repeat(6, 1fr) / repeat(6, 1fr);
border: 2px solid #696989;
padding: 10px;
width: 400px;
height: 300px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
background-color: pink;
grid-column: 1 / 4;
grid-row: 1 / 5;
order: 3;
}
#elem2 {
background-color: orange;
grid-column: 2 / 5;
grid-row: 3 / 6;
order: 2;
}
#elem3 {
background-color: green;
grid-column: 3 / 6;
grid-row: 2 / 4;
order: 1;
}
:
Redosled preklapanja elemenata pomoću svojstva z-index
Sada primenimo svojstvo z-index,
koje omogućava podešavanje redosleda
pozicioniranja elemenata duž z-ose:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
</div>
#parent {
display: grid;
grid: repeat(6, 1fr) / repeat(6, 1fr);
border: 2px solid #696989;
padding: 10px;
width: 400px;
height: 300px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
background-color: pink;
grid-column: 1 / 4;
grid-row: 1 / 5;
z-index: 1;
}
#elem2 {
background-color: orange;
grid-column: 2 / 5;
grid-row: 3 / 6;
z-index: 3;
}
#elem3 {
background-color: green;
grid-column: 3 / 6;
grid-row: 2 / 4;
z-index: 2;
}
:
Kao što se vidi iz dobijenog rezultata,
viša vrednost svojstva z-index
postavlja element iznad drugih
elemenata sa nižim vrednostima.
Kombinovanje preklapanja elemenata pomoću svojstava order i z-index
Ako smo promenili redosled za elemente
pomoću z-index i order, onda
prioritet ostaje za z-index.
Zahvaljujući tome možemo menjati redosled elemenata,
ali pritom ne izgubiti kontrolu nad njihovim preklapanjem:
<div id="parent">
<div id="elem1">1</div>
<div id="elem2">2</div>
<div id="elem3">3</div>
</div>
#parent {
display: grid;
grid: repeat(6, 1fr) / repeat(6, 1fr);
border: 2px solid #696989;
padding: 10px;
width: 400px;
height: 300px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
background-color: pink;
grid-column: 1 / 4;
grid-row: 1 / 5;
order: 3;
z-index: 1;
}
#elem2 {
background-color: orange;
grid-column: 2 / 5;
grid-row: 3 / 6;
order: 1;
z-index: 2;
}
#elem3 {
background-color: green;
grid-column: 3 / 6;
grid-row: 2 / 4;
order: 1;
z-index: 3;
}
:
Praktični zadaci
Pretpostavimo da u našem grid-u postoje četiri elementa:
<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: repeat(6, 1fr) / repeat(6, 1fr);
border: 2px solid #696989;
padding: 10px;
width: 400px;
height: 300px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
background-color: pink;
}
#elem2 {
background-color: orange;
}
#elem3 {
background-color: green;
}
#elem4 {
background-color: lightblue;
}
Postavite sve elemente u
skladu sa sledećim primerom,
koristeći svojstvo order:
A sada za rešavanje prethodnog zadatka
primenite svojstvo z-index.
Pretpostavimo da u našem grid-u postoje četiri elementa:
<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: repeat(6, 1fr) / repeat(6, 1fr);
border: 2px solid #696989;
padding: 10px;
width: 400px;
height: 300px;
}
#parent > div {
padding: 10px;
border: 1px solid #696989;
}
#elem1 {
background-color: pink;
}
#elem2 {
background-color: orange;
}
#elem3 {
background-color: green;
}
#elem4 {
background-color: lightblue;
}
Postavite sve elemente u
skladu sa sledećim primerom,
koristeći svojstvo order:
A sada za rešavanje prethodnog zadatka
primenite svojstvo z-index.