Flex-elementtien nollahalu CSS:ssä
Jos flex-grow on nolla jollekin
elementille, niin tämä elementti ei osallistu
vapaan tilan jakamiseen.
Oletusarvoisesti halulla on
nolla-arvo, ja siksi elementit, joille ei ole asetettu
flex-grow -arvoa, eivät jaa vapaata tilaa
keskenään.
Tehdään esimerkkinä laskelma.
Oletetaan, että meillä on kolme flex-elementtiä,
joiden kukin leveys on 100px. Oletetaan, että ensimmäisellä
elementillä ei ole flex-grow -arvoa (tai se on
yhtä suuri kuin 0), toisella elementillä on flex-grow,
yhtä suuri kuin 2, ja kolmannella - yhtä suuri kuin 3.
Oletetaan, että vanhemman leveys on 500px.
Silloin vapaa tila on
200px, ja yhdelle flex-grow -yksikölle
tulee . Tuloksena ensimmäisen elementin leveys
pysyy 200px / 5 = 40px100px,
koska se ei osallistu jakoon,
toisen leveys on , ja kolmannen leveys - 100px + 2 * 40px
= 180px.
100px
+ 3 * 40px = 220px
Käytännön tehtävät
Kaikissa alla olevissa tehtävissä sinulle esitetään
koodi flex-elementeillä, joilla on
leveys ja flex-grow. Esitetyn
koodin perusteella laske, mitkä mitat kullakin
elementeistä on. Suorita sitten koodi
ja tarkista laskelmat mittaamalla todelliset
elementtien leveydet.
<div class="parent">
<div class="child elem1">1</div>
<div class="child elem2">2</div>
<div class="child elem3">3</div>
</div>
.parent {
display: flex;
width: 500px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 200px;
flex-grow: 0;
}
.elem2 {
width: 100px;
flex-grow: 1;
}
.elem3 {
width: 100px;
flex-grow: 1;
}
<div class="parent">
<div class="child elem1">1</div>
<div class="child elem2">2</div>
<div class="child elem3">3</div>
</div>
.parent {
display: flex;
width: 900px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 300px;
flex-grow: 0;
}
.elem2 {
width: 200px;
flex-grow: 3;
}
.elem3 {
width: 100px;
flex-grow: 2;
}
<div class="parent">
<div class="child elem1">1</div>
<div class="child elem2">2</div>
<div class="child elem3">3</div>
<div class="child elem4">4</div>
</div>
.parent {
display: flex;
width: 700px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 200px;
flex-grow: 0;
}
.elem2 {
width: 200px;
flex-grow: 0;
}
.elem3 {
width: 100px;
flex-grow: 1;
}
.elem4 {
width: 100px;
flex-grow: 1;
}