国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Table of Contents
flex-shrink: How much an item can shrink
flex-basis: The starting size before growing/shrinking
Putting it all together
Home Web Front-end CSS Tutorial What do the flex-grow, flex-shrink, and flex-basis properties do?

What do the flex-grow, flex-shrink, and flex-basis properties do?

Jun 24, 2025 am 12:20 AM
css flexbox

In 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.

What do the flex-grow, flex-shrink, and flex-basis properties do?

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 have 1 .
  • If one item is 2 and others are 1 , 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 like 50% .
  • 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 → lets flex-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, setting flex-basis to 0 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!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

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

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

How can CSS be used to implement dark mode theming on a website? How can CSS be used to implement dark mode theming on a website? Jun 19, 2025 am 12:51 AM

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

What is 'render-blocking CSS'? What is 'render-blocking CSS'? Jun 24, 2025 am 12:42 AM

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.

Can you explain the difference between em, rem, px, and viewport units (vh, vw)? Can you explain the difference between em, rem, px, and viewport units (vh, vw)? Jun 19, 2025 am 12:51 AM

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

External vs. Internal CSS: What's the Best Approach? External vs. Internal CSS: What's the Best Approach? Jun 20, 2025 am 12:45 AM

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

Does my CSS must be on lower case? Does my CSS must be on lower case? Jun 19, 2025 am 12:29 AM

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

What are the key differences between inline, block, inline-block, and flex display values? What are the key differences between inline, block, inline-block, and flex display values? Jun 20, 2025 am 01:01 AM

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

CSS: When Does Case Matter (and When Doesn't)? CSS: When Does Case Matter (and When Doesn't)? Jun 19, 2025 am 12:27 AM

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.

What are CSS counters? What are CSS counters? Jun 19, 2025 am 12:34 AM

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

See all articles