Web Wish 22: Flex-Wrap Balance
When using flexbox to layout items in multiple rows, you easily end up with only one or a few items on the last row. All the remaining space is distributed to the last row.
data:image/s3,"s3://crabby-images/dc2c0/dc2c0780ab510cf3ed6d61106eb8bdc648c04eb2" alt="Illustration of a flex container with 10 items.
It has three rows with three items each, and the fourth row has a single item"
If you're also using flex: auto
on the items to make them fill the entire row,
the items on that last row can end up awkwardly large.
data:image/s3,"s3://crabby-images/79225/792253d5309ae7f115eb2847133eab912ec35806" alt="Illustration of a flex container with 10 items.
It has three rows with three items each, and the fourth row has a single item.
The items are stretched to fill the entire row, making the last item as wide as the container."
What if we could control this, similarly to how we control text wrapping with text-wrap: balance
?
Then we could ensure a more even balancing, and that the last row does not end up with a single item.
data:image/s3,"s3://crabby-images/85897/8589716e92f1f2431df73d14f1623052700fdcfa" alt="Illustration of a flex container with 10 items.
It has four rows in total. The first two rows contains three items each, while the remaining two rows contain two items each.
The items are stretched to fill the entire row."
But, there's room to improve!
A normal pattern is to give the first items in a layout some extra focus. What if we could control how the wrapping algorithm distribute the extra space? Then we could control whether the remaining space would be distributed towards the start or the end of the cross axis.
data:image/s3,"s3://crabby-images/9a1a2/9a1a20f891e57432682623d93beca8519045d9eb" alt="Illustration of a flex container with 10 items.
It has four rows in total. The first two rows contains two items each, while the remaining two rows contain three items each.
The items are stretched to fill the entire row."
This would help immensely when setting up a product page or an image gallery.
For Christmas, I'm hoping the CSS working group will resolve to specify flex-wrap balancing.
Relevant issues and PRs: