Регулирование сжатия флекс блоков в CSS
По умолчанию от всех элементов отщипываются
кусочки, пропорциональные ширине элемента.
Однако, можно сделать так, чтобы от некоторых
элементов отщипывались большие или меньшие
куски. Для этого существует специальное свойство
flex-shrink
.
Данное свойство представляет собой некоторый
вес, на который будет умножаться ширина элемента
при подсчете отщипываемого кусочка по уже
приведенной выше формуле. К примеру, если
ширина элемента равна 200px
, а его
flex-shrink
равен 3
, то взвешенная
(т.е. умноженная на вес) ширина элемента
получится равна:
200px
* 3
= 600px
Формула с учетом flex-shrink
будет
иметь следующий вид: отриц. св. пространство
* (взвешенная ширина элемента / сумма всех
взвеш. ширин элементов).
Давайте посмотрим на примере. Пусть у нас
есть 4
элемента. Пусть ширина первого
элемента равна 400px
, а flex-shrink
равен 2
, ширина остальных элементов
- 200px
, а их flex-shrink
равен
1
. Пусть ширина родителя 900px
.
Суммарная ширина элементов равна:
400px
+ 3
* 200px
= 1000px
Отрицательное свободное пространство будет равно:
1000px
- 900px
= 100px
Суммарная взвешенная ширина элементов равна:
400px
* 2
+ 200px
* 1
+ 200px
* 1
+ 200px
* 1
= 1400px
Взвешенная ширина первого элемента равна:
400px
* 2
= 800px
От первого элемента отщипнется следующий кусочек:
100px
* (800px
/ 1400px
) = 100px
* 0.57
= 57.14px
Ширина элемента будет равна:
400px
- 57
.14px
= 342.86px
~ 343px
Взвешенная ширина каждого из остальных элемента равна:
200px
* 1
= 200px
От каждого элемента отщипнется следующий кусочек:
400px
- 57.14px
= 342.86px
~ 343px
Ширина элемента будет равна:
200px
- 14.2px
= 185.8px
~ 186px
Реализуйте описанные блоки и проверьте измерением, что ширина элементов будет действительно равна рассчитанной нами.
Рассчитайте ширину блоков, а затем проверьте расчеты измерением:
<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;
}
Рассчитайте ширину блоков, а затем проверьте расчеты измерением:
<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;
}
Рассчитайте ширину блоков, а затем проверьте расчеты измерением:
<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;
}