Nulová chamtivost flex elementů v CSS
Pokud je flex-grow roven nule pro nějaký
prvek, pak se tento prvek nebude podílet
na rozdělování volného prostoru.
Ve výchozím nastavení má chamtivost právě
nulovou hodnotu, a proto prvky bez nastaveného
flex-grow si mezi sebou ne rozdělují volný prostor.
Pojďme si pro příklad provést nějaký
výpočet. Předpokládejme, že máme tři flex prvky,
každý se šířkou 100px. Nechť první
prvek nemá flex-grow (nebo je
rovno 0), druhý prvek má flex-grow,
rovno 2, a třetí - rovno 3.
Nechť šířka rodiče je 500px.
Pak bude volný prostor roven
200px, a na jednu jednotku flex-grow
připadne . Vyjde nám, že šířka
prvního prvku zůstane 200px / 5 = 40px100px,
protože se neúčastní rozdělování,
šířka druhého bude , a šířka třetího - 100px + 2 * 40px
= 180px.
100px
+ 3 * 40px = 220px
Praktické úlohy
Ve všech níže uvedených úlohách vám bude představen
nějaký kód s flex prvky, které mají
šířku a flex-grow. Podle představeného
kódu vypočítejte, jaké rozměry bude mít
každý z prvků. Poté kód spusťte
a ověřte své výpočty změřením skutečných
šířek prvků.
<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;
}