Mbivendosja e Elementeve të CSS Grid
Sistemi i grid-it parashikon mundësinë e
mbivendosjes së disa elementeve mbi të tjerët kur
zonat e grid-it kryqëzohen ose kur përcaktohen
margjina negative të jashtme.
Mbivendosja mund të ndodhë si parazgjedhje,
por gjithashtu për çdo element mund të përcaktohet në një rend të caktuar
përmes vetive z-index dhe order,
si dhe kombinimit të tyre.
Mbivendosja e elementeve në grid si parazgjedhje
Le të themi se kemi një tabelë, në të cilën elementet mbivendosen me njëri-tjetrin:
<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;
}
:
Ndryshimi i rendit të mbivendosjes së elementeve duke përdorur vetinë order
Tani le të aplikojmë vetinë order,
duke e përcaktuar atë në çdo element fëmijë:
<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;
}
:
Rendi i mbivendosjes së elementeve duke përdorur vetinë z-index
Tani le të aplikojmë vetinë z-index,
e cila lejon rregullimin e rendit
të vendosjes së elementeve përgjatë boshtit-z:
<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;
}
:
Siç shihet nga rezultati i marrë,
vlera më e lartë e vetisë z-index
i vendos elementit një pozicion mbi elementët e tjerë
me vlera më të ulëta.
Kombinimi i mbivendosjes së elementeve duke përdorur vetitë order dhe z-index
Nëse kemi ndryshuar rendin për elementët
duke përdorur z-index dhe order, atëherë
prioriteti do të mbetet për z-index.
Falë kësaj mund të ndryshohet rendi i elementeve,
por në të njëjtën kohë të mos humbasë kontrollin mbi mbivendosjen e tyre:
<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;
}
:
Detyra praktike
Le të themi se në grid-in tonë ka katër elemente:
<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;
}
Vendosni të gjithë elementet në
përputhje me shembullin e mëposhtëm,
duke përdorur vetinë order:
Dhe tani për zgjidhjen e detyrës së mëparshme
aplikoni vetinë z-index.
Le të themi se në grid-in tonë ka katër elemente:
<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;
}
Vendosni të gjithë elementet në
përputhje me shembullin e mëposhtëm,
duke përdorur vetinë order:
Dhe tani për zgjidhjen e detyrës së mëparshme
aplikoni vetinë z-index.