Uravnavanje stiskanja fleksibilnih blokov v CSS
Privzeto se vsem elementom odvzamejo
koski, sorazmerni s širino elementa.
Vendar pa je mogoče narediti tako, da se nekaterim
elementom odvzamejo večji ali manjši
koski. Za to obstaja posebna lastnost
flex-shrink.
Ta lastnost predstavlja določeno
utež, s katero se bo pomnožila širina elementa
pri izračunu odvzetega koska po že
navedeni formuli. Na primer, če je
širina elementa enaka 200px, njegov
flex-shrink pa je 3, potem bo utežena
(tj. pomnožena z utežjo) širina elementa
enaka:
200px * 3 = 600px
Formula ob upoštevanju flex-shrink bo
imela naslednjo obliko: neg. prostor
* (utežena širina elementa / vsota vseh
uteženih širin elementov).
Poglejmo si primer. Predpostavimo, da imamo
4 elemente. Naj bo širina prvega
elementa enaka 400px, flex-shrink
pa 2, širina preostalih elementov
- 200px, njihov flex-shrink pa
1. Naj bo širina starša 900px.
Skupna širina elementov je enaka:
400px + 3 * 200px = 1000px
Negativni prosti prostor bo enak:
1000px - 900px = 100px
Skupna utežena širina elementov je enaka:
400px * 2 + 200px * 1 + 200px * 1 + 200px * 1 = 1400px
Utežena širina prvega elementa je enaka:
400px * 2 = 800px
Od prvega elementa se bo odvzel naslednji košček:
100px * (800px / 1400px) = 100px * 0.57 = 57.14px
Širina elementa bo enaka:
400px - 57.14px = 342.86px ~ 343px
Utežena širina vsakega od preostalih elementov je enaka:
200px * 1 = 200px
Od vsakega elementa se bo odvzel naslednji košček:
100px * (200px / 1400px) = 100px * 0.142 = 14.2px
Širina elementa bo enaka:
200px - 14.2px = 185.8px ~ 186px
Implementirajte opisane bloke in preverite z merjenjem, da bo širina elementov res enaka tisti, ki smo jo izračunali.
Izračunajte širino blokov in nato preverite izračune z merjenjem:
<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;
}
Izračunajte širino blokov in nato preverite izračune z merjenjem:
<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;
}
Izračunajte širino blokov in nato preverite izračune z merjenjem:
<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;
}