This property specifies how much of the remaining space in the flex container should be assigned to the item (the flex grow factor).
The main size is either the width or height of the item, depending on the flex-direction
value.
The remaining space, or positive free space, is the size of the flex container minus the size of all flex items' sizes together. If all sibling items have the same flex grow factor, then all items will receive the same share of remaining space. The common practice is to set flex-grow: 1
, but setting the flex grow factor for all the flex items to 88
, 100
, 1.2
, or any other value greater than 0
will produce the same result: the value is a ratio.
If the flex-grow
values differ, the positive free space is distributed according to the ratio defined by the different flex grow factors. The flex-grow
factor values of all the sibling flex items are added together. The flex container's positive free space, if any, is then divided by that total. The main size of each flex item with a flex-grow
value greater than 0
will grow by this quotient multiplied by its own growth factor.
For example, if four 100px
flex items are in a 700px
container and the flex items have flex-grow
factors of 0
, 1
, 2
, and 3
, respectively, the total main size of the three items is 400px
, meaning there is 300px
of positive free space to be distributed. There are a total of 6 grow factors (3 + 2 + 1
), therefore each grow factor is equal to 50px
((300px / 6 )
. Each flex item is given an amount of positive free space equal to this amount multiplied by its flex-grow
value — so 0
, 50px
, 100px
, and 150px
respectively. The total flex item sizes are therefore 100px
, 150px
, 200px
, and 250px
respectively.
flex-grow
is generally used alongside the other flex
shorthand properties, flex-shrink
and flex-basis
. Using the flex
shorthand property is recommended to ensure all values are set.