What do the flex-grow, flex-shrink, and flex-basis properties do?
Jun 24, 2025 am 12:20 AMIn a Flexbox layout, flex-grow, flex-shrink, and flex-basis are the three core attributes that control the behavior of child elements. 1. flex-grow determines how much the element can expand when there is extra space, and the larger the value, the larger the proportion; 2. flex-shrink determines the proportion of element shrinkage when there is insufficient space, and the larger the value, the more shrinkage; 3. flex-basis is the initial size of an element before it is stretched and can be set to a fixed value or percentage. They are usually set together by flex abbreviation properties. For example, flex: 1 1 200px means that equal proportion expansion and shrinkage are allowed, and adjusted from 200px as the starting point, thereby achieving a flexible and controllable layout effect.
When you use Flexbox for layout, flex-grow
, flex-shrink
, and flex-basis
are the three main properties that control how flex items behave inside a flex container. They work together as part of the shorthand flex
property, but each has its own specific role.
Here's what they do in simple terms:
flex-grow: How much an item can grow
This tells the browser how much space an item should take up relative to other items when there's extra space in the container.
- A value of
0
means it won't grow at all. - A value of
1
means it will grow equally with others that also have1
. - If one item is
2
and others are1
, it'll take up twice as much space as the others (as long as there's room).
For example:
.item { flex-grow: 1; }
This is commonly used to make all items the same width, filling the container evenly.
flex-shrink: How much an item can shrink
When there's not enough space, this determines how much an item will shrink compared to others.
- A value of
1
(default) means it can shrink normally. - A value of
0
means it won't shrink at all — useful if you have content that shouldn't be compressed. - Higher values ??mean the item will shrink more than others.
So if you have one item that must stay wide even when space is tight, you might set:
.item { flex-shrink: 0; }
flex-basis: The starting size before growing/shrinking
This is basically the “starting point” for how big the item is before any growing or shrinking happens.
- You can set it to a fixed size like
200px
, or a percentage like50%
. - It can also be set to
auto
, which means the size is based on the content or any explicit width/height.
Some common setups:
-
flex-basis: auto
→ uses the element's width or height -
flex-basis: 0
→ letsflex-grow
take full control of distribution -
flex-basis: 30%
→ give a starting size, then adjusts based on grow/shrink
Tip: When using
flex-grow
with multiple items, settingflex-basis
to0
often give more predictable results because it makes space distribution purely based on the growth factor.
Putting it all together
You'll usually see these three used in the shorthand flex
property like this:
.item { flex: 1 1 200px; }
That translates to:
-
flex-grow: 1;
-
flex-shrink: 1;
-
flex-basis: 200px;
If you want equal-width columns that don't shrink too much, maybe go with:
flex: 1 0 25%;
Or if you just want something to fill space and ignore its original size:
flex: 1 1 0;
Basically that's it. These three properties may seem confusing at first, but once you understand their individual roles — grow for extra space, shrink for tight spots, and basis as the starting size — it gets a lot easier to control your layouts.
The above is the detailed content of What do the flex-grow, flex-shrink, and flex-basis properties do?. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

ToimplementdarkmodeinCSSeffectively,useCSSvariablesforthemecolors,detectsystempreferenceswithprefers-color-scheme,addamanualtogglebutton,andhandleimagesandbackgroundsthoughtfully.1.DefineCSSvariablesforlightanddarkthemestomanagecolorsefficiently.2.Us

CSS blocks page rendering because browsers view inline and external CSS as key resources by default, especially with imported stylesheets, header large amounts of inline CSS, and unoptimized media query styles. 1. Extract critical CSS and embed it into HTML; 2. Delay loading non-critical CSS through JavaScript; 3. Use media attributes to optimize loading such as print styles; 4. Compress and merge CSS to reduce requests. It is recommended to use tools to extract key CSS, combine rel="preload" asynchronous loading, and use media delayed loading reasonably to avoid excessive splitting and complex script control.

The topic differencebetweenem, Rem, PX, andViewportunits (VH, VW) LiesintheirreFerencepoint: PXISFixedandbasedonpixelvalues, emissrelative EtothefontsizeFheelementoritsparent, Remisrelelatotherootfontsize, AndVH/VwarebaseDontheviewporttimensions.1.PXoffersprecis

ThebestapproachforCSSdependsontheproject'sspecificneeds.Forlargerprojects,externalCSSisbetterduetomaintainabilityandreusability;forsmallerprojectsorsingle-pageapplications,internalCSSmightbemoresuitable.It'scrucialtobalanceprojectsize,performanceneed

No,CSSdoesnothavetobeinlowercase.However,usinglowercaseisrecommendedfor:1)Consistencyandreadability,2)Avoidingerrorsinrelatedtechnologies,3)Potentialperformancebenefits,and4)Improvedcollaborationwithinteams.

Choosing the correct display value in CSS is crucial because it controls the behavior of elements in the layout. 1.inline: Make elements flow like text, without occupying a single line, and cannot directly set width and height, suitable for elements in text, such as; 2.block: Make elements exclusively occupy one line and occupy all width, can set width and height and inner and outer margins, suitable for structured elements, such as; 3.inline-block: has both block characteristics and inline layout, can set size but still display in the same line, suitable for horizontal layouts that require consistent spacing; 4.flex: Modern layout mode, suitable for containers, easy to achieve alignment and distribution through justify-content, align-items and other attributes, yes

In CSS, selector and attribute names are case-sensitive, while values, named colors, URLs, and custom attributes are case-sensitive. 1. The selector and attribute names are case-insensitive, such as background-color and background-Color are the same. 2. The hexadecimal color in the value is case-sensitive, but the named color is case-sensitive, such as red and Red is invalid. 3. URLs are case sensitive and may cause file loading problems. 4. Custom properties (variables) are case sensitive, and you need to pay attention to the consistency of case when using them.

CSScounterscanautomaticallynumbersectionsandlists.1)Usecounter-resettoinitialize,counter-incrementtoincrease,andcounter()orcounters()todisplayvalues.2)CombinewithJavaScriptfordynamiccontenttoensureaccurateupdates.
