search
HomeWeb Front-endCSS TutorialMaking width and flexible items play nice together

Making width and flexible items play nice together

Short answer: flex-shrink and flex-basis properties are most likely the solutions you are looking for.

Detailed answers

Suppose you want the image and text to be arranged side by side like this:

Now, let's say you use Flexbox to achieve this. Setting the parent element to display: flex; is a good start.

 <code>.container { display: flex; }</code>

turn out……

Oops! OK, I think this is acceptable. It makes sense that the image is close to the text, because we do not set the width of the image. Ideally, we want the image to have a fixed width, and the text then takes up the remaining space.

OK, let's do it!

 <code>.container { display: flex; } img { width: 50px; margin-right: 20px; }</code>

This looks great in Chrome. But wait, what? If we check the image tag in Firefox DevTools, we will find that it is not the width value we set at all:

We can use min-width to force the image to reach the 50px width we want:

 <code>img { min-width: 50px; margin-right: 20px; }</code>

However, this will only help set the width, so we have to add a margin as well.

 <code>img { min-width: 50px; margin-right: 20px; }</code>

That's it. Better in Firefox, and still works in Chrome.

More detailed answers

I realized that the image is compressed because we need to use flex-shrink property to tell Flex items not to reduce size, regardless of whether they have width or not.

flex-shrink value of all Flex projects is 1. We need to set the image element to 0:

 <code>.container { display: flex; } img { width: 50px; margin-right: 20px; flex-shrink: 0; }</code>

Better and better! But we can still make more improvements.

Final answer

We can organize it further because flex-shrink is included in flex abbreviation property.

 <code>flex: none | [ ? || ]</code>

If we set the flex-shrink value to 0 and set flex-basis value to the default width we want the image to have, then we can get rid of width attribute completely.

 <code>.container { display: flex; } img { flex: 0 0 50px; margin-right: 20px; }</code>

Oh, yeah:

Another example

flex-shrink property solves a lot of other problems, and it is very important if you want to start using Flexbox. Here is another example of why: I stumbled upon another question similar to the above, which I mentioned in my recent newsletter. I'm building a navigation component that allows the user to scroll multiple projects left and right. While checking my work, I noticed the following issues:

Longer navigation items shouldn't be wrapping like that - but I finally got why this happens, thanks to previous questions. If you set flex-shrink property to 0, it will tell each item in this navigation not to shrink, but to take the width of the content, as follows:

Yes, we can take the extra step again to use the flex attribute, this time using auto as flex-basis because we want to consider as much space as possible for all items when allocating space in the navigation container.

Long live! We solved it. Although the answer is just a line of code, it is crucial to creating truly flexible elements.

The above is the detailed content of Making width and flexible items play nice together. For more information, please follow other related articles on the PHP Chinese website!

Statement
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
The Ultimate Guide to Linking CSS Files in HTMLThe Ultimate Guide to Linking CSS Files in HTMLMay 13, 2025 am 12:02 AM

Linking CSS files to HTML can be achieved by using elements in part of HTML. 1) Use tags to link local CSS files. 2) Multiple CSS files can be implemented by adding multiple tags. 3) External CSS files use absolute URL links, such as. 4) Ensure the correct use of file paths and CSS file loading order, and optimize performance can use CSS preprocessor to merge files.

CSS Flexbox vs Grid: a comprehensive reviewCSS Flexbox vs Grid: a comprehensive reviewMay 12, 2025 am 12:01 AM

Choosing Flexbox or Grid depends on the layout requirements: 1) Flexbox is suitable for one-dimensional layouts, such as navigation bar; 2) Grid is suitable for two-dimensional layouts, such as magazine layouts. The two can be used in the project to improve the layout effect.

How to Include CSS Files: Methods and Best PracticesHow to Include CSS Files: Methods and Best PracticesMay 11, 2025 am 12:02 AM

The best way to include CSS files is to use tags to introduce external CSS files in the HTML part. 1. Use tags to introduce external CSS files, such as. 2. For small adjustments, inline CSS can be used, but should be used with caution. 3. Large projects can use CSS preprocessors such as Sass or Less to import other CSS files through @import. 4. For performance, CSS files should be merged and CDN should be used, and compressed using tools such as CSSNano.

Flexbox vs Grid: should I learn them both?Flexbox vs Grid: should I learn them both?May 10, 2025 am 12:01 AM

Yes,youshouldlearnbothFlexboxandGrid.1)Flexboxisidealforone-dimensional,flexiblelayoutslikenavigationmenus.2)Gridexcelsintwo-dimensional,complexdesignssuchasmagazinelayouts.3)Combiningbothenhanceslayoutflexibilityandresponsiveness,allowingforstructur

Orbital Mechanics (or How I Optimized a CSS Keyframes Animation)Orbital Mechanics (or How I Optimized a CSS Keyframes Animation)May 09, 2025 am 09:57 AM

What does it look like to refactor your own code? John Rhea picks apart an old CSS animation he wrote and walks through the thought process of optimizing it.

CSS Animations: Is it hard to create them?CSS Animations: Is it hard to create them?May 09, 2025 am 12:03 AM

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

@keyframes CSS: The most used tricks@keyframes CSS: The most used tricksMay 08, 2025 am 12:13 AM

@keyframesispopularduetoitsversatilityandpowerincreatingsmoothCSSanimations.Keytricksinclude:1)Definingsmoothtransitionsbetweenstates,2)Animatingmultiplepropertiessimultaneously,3)Usingvendorprefixesforbrowsercompatibility,4)CombiningwithJavaScriptfo

CSS Counters: A Comprehensive Guide to Automatic NumberingCSS Counters: A Comprehensive Guide to Automatic NumberingMay 07, 2025 pm 03:45 PM

CSSCountersareusedtomanageautomaticnumberinginwebdesigns.1)Theycanbeusedfortablesofcontents,listitems,andcustomnumbering.2)Advancedusesincludenestednumberingsystems.3)Challengesincludebrowsercompatibilityandperformanceissues.4)Creativeusesinvolvecust

See all articles

Hot AI Tools

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.

Undress AI Tool

Undress AI Tool

Undress images for free

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 Article

Hot Tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

PhpStorm Mac version

PhpStorm Mac version

The latest (2018.2.1) professional PHP integrated development tool

mPDF

mPDF

mPDF is a PHP library that can generate PDF files from UTF-8 encoded HTML. The original author, Ian Back, wrote mPDF to output PDF files "on the fly" from his website and handle different languages. It is slower than original scripts like HTML2FPDF and produces larger files when using Unicode fonts, but supports CSS styles etc. and has a lot of enhancements. Supports almost all languages, including RTL (Arabic and Hebrew) and CJK (Chinese, Japanese and Korean). Supports nested block-level elements (such as P, DIV),