Home > Web Front-end > CSS Tutorial > How Does `box-sizing` Affect Flexbox Shrink Factor Calculations with Padding?

How Does `box-sizing` Affect Flexbox Shrink Factor Calculations with Padding?

Susan Sarandon
Release: 2024-12-05 08:23:11
Original
659 people have browsed it

How Does `box-sizing` Affect Flexbox Shrink Factor Calculations with Padding?

Flexbox Shrink Factor with Padding and Border-Box

Flexbox dynamically adjusts the size of items within a container based on available space. The flex-shrink property controls how an item shrinks when the container is too small to accommodate all its contents.

When padding is applied to flex items, the outer width includes both the padding and content, while the inner width only encompasses the content itself. The box-sizing property determines which width is used in flex calculations.

Without Padding

The formula for calculating scaled flex shrink factors (inner flex base size multiplied by flex shrink factor) remains the same:

:nth-child(1)  2 * 300 = 600
:nth-child(2)  1 * 200 = 200
:nth-child(3)  2 * 100 = 200

TOTAL = 1000
Copy after login

With a total negative free space of -200px, the shrink factors and resulting inner widths are:

:nth-child(1)  600 / 1000 = .6
:nth-child(1)  .6 * -200px = -120px (resulting inner width: 180px)
:nth-child(2)  200 / 1000 = .2
:nth-child(2)  .2 * -200px =  -40px (resulting inner width: 160px)
:nth-child(3)  200 / 1000 = .2
:nth-child(3)  .2 * -200px =  -40px (resulting inner width:  60px)
Copy after login

With Padding

When padding is added, the available space for content decreases, leading to different inner widths.

Without Border-box

The shrink factors are calculated based on the inner flex base size, which does not include padding. The resulting inner widths are:

:nth-child(1)  2 * 280 = 560
:nth-child(2)  1 * 180 = 180
:nth-child(3)  2 * 80 = 160

TOTAL = 900
Copy after login

With a negative free space of -260px, the shrink factors and inner widths become:

:nth-child(1)  560 / 900 = .622
:nth-child(1)  .622 * -260px = -162px (resulting inner width: 118px)
:nth-child(2)  180 / 900 = .2
:nth-child(2)  .2 * -260px =  -52px (resulting inner width: 128px)
:nth-child(3)  160 / 900 = .178
:nth-child(3)  .178 * -260px =  -46px (resulting inner width: 34px)
Copy after login

With Border-box

When box-sizing: border-box is applied, the flex base size includes both content and padding. The shrink factors are calculated using the outer flex base size, which is the specified flex property multiplied by the available space.

:nth-child(1)  2 * 320 = 640
:nth-child(2)  1 * 220 = 220
:nth-child(3)  2 * 120 = 240

TOTAL = 1100
Copy after login

With a negative free space of -200px, the shrink factors and inner widths are:

:nth-child(1)  640 / 1100 = .582
:nth-child(1)  .582 * -200px = -116px (resulting inner width: 204px)
:nth-child(2)  220 / 1100 = .2
:nth-child(2)  .2 * -200px =  -40px (resulting inner width: 180px)
:nth-child(3)  240 / 1100 = .218
:nth-child(3)  .218 * -200px =  -44px (resulting inner width: 76px)
Copy after login

The above is the detailed content of How Does `box-sizing` Affect Flexbox Shrink Factor Calculations with Padding?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
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
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template