Разная ширина элементов и сжимаемость флекс блоков в CSS

Пусть теперь наши элементы имеют разную ширину. В этом случае отщепляемый кусочек будет пропорционален ширине этого элемента и будет вычисляться по следующей формуле: отриц. св. пространство * (ширина элемента / сумма всех ширин элементов).

Пусть у нас есть 4 элемента. Пусть ширина первого элемента равна 400px, ширина остальных элементов - 200px, а ширина родителя 900px.

Суммарная ширина элементов равна:

400px + 3 * 200px = 1000px

Тогда отрицательное свободное пространство будет равно:

1000px - 900px = 100px

Найдем сколько отщипнется первого элемента:

100px * (400px / 1000px) = 40px

То есть его ширина будет равна:

400px - 40px = 360px

Найдем сколько от каждого из остальных элементов:

100px * (200px / 1000px) = 20px

То есть ширина этих элементов будет равна:

200px - 20px = 180px

Реализуйте описанные блоки и проверьте измерением, что ширина элементов будет действительно равна рассчитанной нами.

Рассчитайте ширину блоков, а затем проверьте расчеты измерением:

<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: 300px; height: 200px; border: 1px solid red; } .child { height: 50px; border: 1px solid green; } .elem1 { width: 300px; } .elem2 { width: 100px; } .elem3 { width: 100px; }



Чат с GPT Компилятор