Алчност при указана ширина на flex блокове в CSS
Нека имаме няколко флекс блока.
Нека на един от тези блокове зададем flex-grow
със стойност 1, а на всички останали елементи
- определена ширина. В резултат ще се получи,
че всички блокове ще имат фиксирана ширина,
а нашия избран алчен блок ще заема
цялото останало налично пространство:
<div class="parent">
<div class="child elem1"></div>
<div class="child elem2"></div>
<div class="child elem3"></div>
</div>
.parent {
display: flex;
width: 400px;
height: 200px;
border: 1px solid red;
}
.child {
height: 50px;
border: 1px solid green;
}
.elem1 {
width: 100px;
}
.elem2 {
flex-grow: 1;
}
.elem3 {
width: 100px;
}
:
Характерният ефект е особено забележим, когато ширината на родителя е в проценти. В този случай при промяна на ширината на родителя нашия алчен блок ще има плаваща ширина, а всички останали - фиксирана: