CSS-gridin elementtien asettaminen päällekkäin
Grid-järjestelmässä on mahdollisuus
asettaa elementtejä päällekkäin, kun
grid-alueet leikkaavat tai kun määritetään
negatiivisia ulomarginaaleja.
Päällekkäisasettuminen voi tapahtua oletusarvoisesti,
mutta jokaiselle elementille voidaan myös asettaa tietty järjestys
ominaisuuksien z-index ja order avulla,
sekä niiden yhdistelmällä.
Elementtien päällekkäisasettuminen gridissä oletusarvoisesti
Oletetaan, että meillä on taulukko, jossa elementit asettuvat päällekkäin:
<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;
}
:
Elementtien päällekkäisasettumisen järjestyksen muuttaminen ominaisuudella order
Käytetään nyt ominaisuutta order,
asettaen sen jokaisessa lapsielementissä:
<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;
}
:
Elementtien päällekkäisasettumisen järjestys ominaisuuden z-index avulla
Käytetään nyt ominaisuutta z-index,
joka mahdollistaa elementtien järjestyksen
säätämisen z-akselin suunnassa:
<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;
}
:
Kuten saadusta tuloksesta voidaan nähdä,
korkein z-index-ominaisuuden arvo
asettaa elementin muiden elementtien päälle,
joiden arvot ovat matalampia.
Elementtien päällekkäisasettumisen yhdistäminen ominaisuuksilla order ja z-index
Jos olemme muuttaneet elementtien järjestystä
ominaisuuksilla z-index ja order, niin
prioriteetti pysyy z-index-ominaisuudella.
Sen ansiosta voidaan muuttaa elementtien järjestystä,
mutta samalla säilyttää kontrolli niiden päällekkäisasettumisesta:
<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;
}
:
Käytännön tehtävät
Oletetaan, että gridissämme on neljä elementtiä:
<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;
}
Sijoita kaikki elementit
seuraavan esimerkin mukaisesti,
käyttäen order-ominaisuutta:
Ratkaise nyt edellinen tehtävä
käyttämällä z-index-ominaisuutta.
Oletetaan, että gridissämme on neljä elementtiä:
<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;
}
Sijoita kaikki elementit
seuraavan esimerkin mukaisesti,
käyttäen order-ominaisuutta:
Ratkaise nyt edellinen tehtävä
käyttämällä z-index-ominaisuutta.