Home Web Front-end HTML Tutorial The wonderful use of the combination of `flex: 1; width: 0;` in Flex layout: Why can the first child element be displayed normally after the second child element is set to `width: 0;`?

The wonderful use of the combination of `flex: 1; width: 0;` in Flex layout: Why can the first child element be displayed normally after the second child element is set to `width: 0;`?

Apr 05, 2025 am 10:42 AM
css flex layout web page layout Why

The wonderful use of the combination of `flex: 1; width: 0;` in Flex layout: Why can the first child element be displayed normally after the second child element is set to `width: 0;`?

Flex layout skills: use flex: 1; width: 0; solve the problem of child elements squeezing

Flex layout is widely used in web layout, but sometimes it encounters the problem of child elements squeezing each other. This article will explore in-depth the use of flex: 1; width: 0; combination and how to avoid the situation where sub-elements in the Flex container are squeezed.

The following code snippet shows a common problem: a Flex container contains two child elements, the first child element sets a fixed width, and the second child element takes up the remaining space, resulting in the first child element being nearly invisible.

<div style="width: 350px; display: flex;">
    <div style="width: 50px; height: 50px; background-color: blanchedalmond;"></div>
    <div style="flex: 1; width: 0; white-space: nowrap;">
        <div>css3 flex layout, text exceeds .css3 flex layout, text exceeds .css3 flex layout, text exceeds .css3 flex layout, text exceeds .</div>
    </div>
</div>
Copy after login

Why can the first child element be displayed normally after adding width: 0; to the second child element? The key lies in the space allocation mechanism of Flex layout.

When display: flex , the child element becomes the Flex project. The Flex layout allocates space according to project properties. By default, the items min-width and min-height are auto . If width is set for only one project, and the other project width is not specified, the items with width set may be compressed. This is why the first element in the above code is squeezed.

However, when the second project sets width: 0; and flex: 1; at the same time, the situation changes. The Flex layout calculates the width of all items. width: auto depends on the element type: block-level elements represent full use of available space, and inline elements represent shrinking to the appropriate size.

A combination of width: 0; and flex: 1; allows the second project to take up no space. flex: 1 allocates remaining space (350px - 50px = 300px) to it. In this way, the first element will not be squeezed.

Although min-width or width: 0; can solve the problem, it is recommended to use flex-shrink: 0; to prevent the first element from being compressed, which is more in line with the design concept of Flex layout.

The above is the detailed content of The wonderful use of the combination of `flex: 1; width: 0;` in Flex layout: Why can the first child element be displayed normally after the second child element is set to `width: 0;`?. 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

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 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)

Hot Topics

Java Tutorial
1655
14
PHP Tutorial
1254
29
C# Tutorial
1228
24
How to display child categories on archive page of parent categories How to display child categories on archive page of parent categories Apr 19, 2025 pm 11:54 PM

Do you want to know how to display child categories on the parent category archive page? When you customize a classification archive page, you may need to do this to make it more useful to your visitors. In this article, we will show you how to easily display child categories on the parent category archive page. Why do subcategories appear on parent category archive page? By displaying all child categories on the parent category archive page, you can make them less generic and more useful to visitors. For example, if you run a WordPress blog about books and have a taxonomy called "Theme", you can add sub-taxonomy such as "novel", "non-fiction" so that your readers can

HTML vs. CSS and JavaScript: Comparing Web Technologies HTML vs. CSS and JavaScript: Comparing Web Technologies Apr 23, 2025 am 12:05 AM

HTML, CSS and JavaScript are the core technologies for building modern web pages: 1. HTML defines the web page structure, 2. CSS is responsible for the appearance of the web page, 3. JavaScript provides web page dynamics and interactivity, and they work together to create a website with a good user experience.

Which 2025 currency exchanges are more secure? Which 2025 currency exchanges are more secure? Apr 20, 2025 pm 06:09 PM

The top ten safe and reliable exchanges in the 2025 cryptocurrency circle include: 1. Binance, 2. OKX, 3. Gate.io (Sesame Open), 4. Coinbase, 5. Kraken, 6. Huobi Global, 7. Gemini, 8. Crypto.com, 9. Bitfinex, 10. KuCoin. These exchanges are rated as safe and reliable based on compliance, technical strength and user feedback.

Why is the rise or fall of virtual currency prices? Why is the rise or fall of virtual currency prices? Why is the rise or fall of virtual currency prices? Why is the rise or fall of virtual currency prices? Apr 21, 2025 am 08:57 AM

Factors of rising virtual currency prices include: 1. Increased market demand, 2. Decreased supply, 3. Stimulated positive news, 4. Optimistic market sentiment, 5. Macroeconomic environment; Decline factors include: 1. Decreased market demand, 2. Increased supply, 3. Strike of negative news, 4. Pessimistic market sentiment, 5. Macroeconomic environment.

Why does the Spring project cause randomness problems due to circular dependencies when starting? Why does the Spring project cause randomness problems due to circular dependencies when starting? Apr 19, 2025 pm 11:21 PM

Understand the randomness of circular dependencies in Spring project startup. When developing Spring project, you may encounter randomness caused by circular dependencies at project startup...

Why is the return value empty when using RedisTemplate for batch query? Why is the return value empty when using RedisTemplate for batch query? Apr 19, 2025 pm 10:15 PM

Why is the return value empty when using RedisTemplate for batch query? When using RedisTemplate for batch query operations, you may encounter the returned results...

How to import the source code of wordpress How to import the source code of wordpress Apr 20, 2025 am 11:24 AM

Importing WordPress source code requires the following steps: Create a sub-theme for theme modification. Import the source code and overwrite the files in the sub-topic. Activate the sub-theme to make it effective. Test the changes to make sure everything works.

See all articles