The flex
CSS shorthand property sets how a flex item will grow or shrink to fit the space available in its flex container.
The flex
CSS shorthand property sets how a flex item will grow or shrink to fit the space available in its flex container.
This property is a shorthand for the following CSS properties:
/* Keyword values */ flex: auto; flex: initial; flex: none; /* One value, unitless number: flex-grow flex-basis is then equal to 0. */ flex: 2; /* One value, width/height: flex-basis */ flex: 10em; flex: 30%; flex: min-content; /* Two values: flex-grow | flex-basis */ flex: 1 30px; /* Two values: flex-grow | flex-shrink */ flex: 2 2; /* Three values: flex-grow | flex-shrink | flex-basis */ flex: 2 2 10%; /* Global values */ flex: inherit; flex: initial; flex: revert; flex: revert-layer; flex: unset;
The flex
property may be specified using one, two, or three values.
<flex-grow>
: then the shorthand expands to flex: <flex-grow> 1 0
.<flex-basis>
: then the shorthand expands to flex: 1 1 <flex-basis>
.none
or one of the global keywords.flex-grow
.flex-shrink
: then the shorthand expands to flex: <flex-grow> <flex-shrink> 0
.flex-basis
: then the shorthand expands to flex: <flex-grow> 1 <flex-basis>
.flex-grow
.flex-shrink
.flex-basis
.initial
The item is sized according to its width
and height
properties. It shrinks to its minimum size to fit the container, but does not grow to absorb any extra free space in the flex container. This is equivalent to setting "flex: 0 1 auto
".
auto
The item is sized according to its width
and height
properties, but grows to absorb any extra free space in the flex container, and shrinks to its minimum size to fit the container. This is equivalent to setting "flex: 1 1 auto
".
none
The item is sized according to its width
and height
properties. It is fully inflexible: it neither shrinks nor grows in relation to the flex container. This is equivalent to setting "flex: 0 0 auto
".
<'flex-grow'>
Defines the flex-grow
of the flex item. Negative values are considered invalid. Defaults to 1
when omitted. (initial is 0
)
<'flex-shrink'>
Defines the flex-shrink
of the flex item. Negative values are considered invalid. Defaults to 1
when omitted. (initial is 1
)
<'flex-basis'>
Defines the flex-basis
of the flex item. A preferred size of 0
must have a unit to avoid being interpreted as a flexibility. Defaults to 0
when omitted. (initial is auto
)
For most purposes, authors should set flex
to one of the following values: auto
, initial
, none
, or a positive unitless number. To see the effect of these values, try resizing the flex containers below:
By default flex items don't shrink below their minimum content size. To change this, set the item's min-width
or min-height
.
Initial value | as each of the properties of the shorthand:
|
---|---|
Applies to | flex items, including in-flow pseudo-elements |
Inherited | no |
Computed value | as each of the properties of the shorthand:
|
Animation type | as each of the properties of the shorthand:
|
This example shows how a flex item with flex: auto
grows to absorb any free space in the container.
<div id="flex-container"> <div id="flex-auto">flex: auto (click to toggle raw box)</div> <div id="flex-initial">flex: initial</div> </div>
#flex-container { display: flex; font-family: Consolas, Arial, sans-serif; } #flex-container > div { padding: 1rem; } #flex-auto { flex: auto; border: 1px solid #f00; } #flex-initial { border: 1px solid #000; }
const flexAuto = document.getElementById("flex-auto"); const flexInitial = document.getElementById("flex-initial"); flexAuto.addEventListener("click", () => { flexInitial.style.display = flexInitial.style.display === "none" ? "block" : "none"; });
The flex container contains two flex items:
The "flex: initial" item takes up as much space as its width requires, but does not expand to take up any more space. All the remaining space is taken up by "flex: auto".
When you click "flex: auto", we set "flex: initial"'s display
property to none
, removing it from the layout. The "flex: auto" item then expands to occupy all the available space in the container.
Specification |
---|
CSS Flexible Box Layout Module Level 1 # flex-property |
Desktop | Mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | WebView Android | Chrome Android | Firefox for Android | Opera Android | Safari on IOS | Samsung Internet | |
flex |
2921 | 1212 | 4920["Since Firefox 28, multi-line flexbox is supported.", "Before Firefox 32, Firefox wasn't able to animate values starting or stopping at0 .", "Until Firefox 61, flex items that are sized according to their content are sized using fit-content , not max-content ."] |
11["Internet Explorer 11 ignores uses ofcalc() in the flex-basis part of the flex syntax. This can be worked around by using the longhand properties instead of the shorthand. See Flexbug #8 for more info.", "Internet Explorer 11 considers a unitless value in the flex-basis part to be syntactically invalid (and will thus be ignored). A workaround is to always include a unit in the flex-basis part of the flex shorthand value. See Flexbug #4 for more info."]10["Internet Explorer 10 and 11 ignore uses ofcalc() in the flex-basis part of the flex syntax. This can be worked around by using the longhand properties instead of the shorthand. See Flexbug #8 for more info.", "Internet Explorer 10 and 11 consider a unitless value in the flex-basis part to be syntactically invalid (and will thus be ignored). A workaround is to always include a unit in the flex-basis part of the flex shorthand value. See Flexbug #4 for more info."] |
12.1 | 97 | ≤374.4 | 2925 | 4920["Since Firefox 28, multi-line flexbox is supported.", "Before Firefox 32, Firefox wasn't able to animate values starting or stopping at0 .", "Until Firefox 61, flex items that are sized according to their content are sized using fit-content, not max-content."] |
12.1 | 97 | 2.01.5 |
© 2005–2023 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/CSS/flex