I read about CSS Grid Layout, and I found the Fr
unit, so I have to try it out.
From w3.org:
Flexible Lengths: the fr unit
A flexible length or is a dimension with the fr unit, which represents a fraction of the leftover space in the grid container. Tracks sized with fr units are called flexible tracks as they flex in response to leftover space similar to how flex items with a zero base size fill space in a flex container.
The distribution of leftover space occurs after all non-flexible track sizing functions have reached their maximum. The total size of such rows or columns is subtracted from the available space, yielding the leftover space, which is then divided among the flex-sized rows and columns in proportion to their flex factor.
Each column or row’s share of the leftover space can be computed as the column or row’s * / .
Read more about fr unit
See this example:
CSS:
.grid-container {
max-width: 100%;
margin: 3em auto;
display: grid;
grid-template-columns: repeat(4, 1fr);
grid-template-rows: 50px 200px 50px;
grid-template-areas: "head head2 head3 head4" "main main2 main3 main4" "footer footer footer footer";
}
Result:
grid-template-columns: repeat(4, 1fr);
1fr is for 1 part of the available space, each column take up the same amount of space.
I will update the 3rd column to size up to 4fr
CSS:
.grid-container {
max-width: 100%;
margin: 3em auto;
display: grid;
grid-template-columns: 1fr 1fr 4fr 1fr;
grid-template-rows: 50px 200px 50px;
grid-template-areas: "head head2 head3 head4" "main main2 main3 main4" "footer footer footer footer";
}
Result:
See a live example:
CSS Grit: Fr Unit by Victor Velazquez (@vicmaster)
on CodePen.
That's all folks!