Regulovanie stláčania flex blokov v CSS
Predvolene sa zo všetkých elementov odštipujú
kúsky úmerné šírke elementu.
Avšak, je možné spraviť to, aby sa z niektorých
elementov odštipovali väčšie alebo menšie
kúsky. Na to existuje špeciálna vlastnosť
flex-shrink.
Táto vlastnosť predstavuje určitú
vahu, na ktorú sa vynásobí šírka elementu
pri výpočte odštipovaného kúsku podľa už
uvedeného vzorca. Napríklad, ak
šírka elementu je 200px, a jeho
flex-shrink je 3, tak zvážená
(t.j. vynásobená vahou) šírka elementu
vyjde:
200px * 3 = 600px
Vzorec s prihliadnutím na flex-shrink bude
mať nasledujúci tvar: záp. voľný priestor
* (zvážená šírka elementu / súčet všetkých
zvážených šírok elementov).
Pozrime sa na príklad. Majme
4 elementy. Nech šírka prvého
elementu je 400px, a flex-shrink
je 2, šírka zvyšných elementov
- 200px, a ich flex-shrink je
1. Nech šírka rodiča je 900px.
Súhrnná šírka elementov je:
400px + 3 * 200px = 1000px
Záporný voľný priestor bude:
1000px - 900px = 100px
Súhrnná zvážená šírka elementov je:
400px * 2 + 200px * 1 + 200px * 1 + 200px * 1 = 1400px
Zvážená šírka prvého elementu je:
400px * 2 = 800px
Z prvého elementu sa odštipne nasledujúci kúsok:
100px * (800px / 1400px) = 100px * 0.57 = 57.14px
Šírka elementu bude:
400px - 57.14px = 342.86px ~ 343px
Zvážená šírka každého zo zvyšných elementov je:
200px * 1 = 200px
Z každého elementu sa odštipne nasledujúci kúsok:
100px * (200px / 1400px) = 100px * 0.142 = 14.2px
Šírka elementu bude:
200px - 14.2px = 185.8px ~ 186px
Realizujte opísané bloky a overte meraním, že šírka elementov bude naozaj rovná nami vypočítanej.
Vypočítajte šírku blokov, a potom overte výpočty meraním:
<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: 200px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 100px;
flex-shrink: 2;
}
.elem2 {
width: 100px;
flex-shrink: 1;
}
.elem3 {
width: 100px;
flex-shrink: 1;
}
Vypočítajte šírku blokov, a potom overte výpočty meraním:
<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: 200px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 100px;
flex-shrink: 3;
}
.elem2 {
width: 100px;
flex-shrink: 2;
}
.elem3 {
width: 100px;
flex-shrink: 1;
}
Vypočítajte šírku blokov, a potom overte výpočty meraním:
<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: 500px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 300px;
flex-shrink: 3;
}
.elem2 {
width: 200px;
flex-shrink: 2;
}
.elem3 {
width: 200px;
flex-shrink: 1;
}
.elem4 {
width: 200px;
flex-shrink: 1;
}