Table of Contents
Why minmax() Defaults to Max
Understanding the Behavior
Achieving Minimum Size Priority
Home Web Front-end CSS Tutorial Why Does `minmax()` in CSS Grid Default to `max` Instead of `min`?

Why Does `minmax()` in CSS Grid Default to `max` Instead of `min`?

Dec 18, 2024 pm 09:15 PM

Why Does `minmax()` in CSS Grid Default to `max` Instead of `min`?

Why minmax() Defaults to Max

You may have noticed that when using minmax() to set the height or width of grid rows or columns, the default behavior is for the track to expand to its maximum size instead of staying at its minimum size. This can be confusing, especially if you're expecting the track to remain at its smallest possible size according to the min() value in minmax().

Understanding the Behavior

The reason for this behavior lies in the default scaling mode of tracks in a grid layout. According to the CSS spec, tracks will typically grow to fill available space until they reach their max size. If the available space is greater than the total minimum size of all tracks, the remaining space is distributed evenly among the unlimited tracks (those without a defined max size).

This default behavior is usually desired, as it ensures that tracks occupy the available space efficiently.

Achieving Minimum Size Priority

To make grid rows or columns remain at their minimum size, but expand to their maximum size when more content is added, you can use a combination of minmax() and other CSS properties:

  • Use minmax(min-size, min-size) for Row/Column Sizing: This will force the tracks to always stay at their minimum size, even when there is available space.
  • Specify max-width/max-height on Grid Items: This will prevent the grid items from exceeding their maximum size, ensuring that the grid rows or columns do not expand beyond their specified maximum size.

Example:

body {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(100px, 100px));
  grid-gap: 20px;
}

.item {
  max-width: 200px;
}
Copy after login

In this example, the grid columns will always have a minimum width of 100px, but will not expand beyond that size. If more content is added to the grid items, the columns will expand to accommodate the new content, but will not exceed their maximum width.

The above is the detailed content of Why Does `minmax()` in CSS Grid Default to `max` Instead of `min`?. 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 Article Tags

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)

Adding Box Shadows to WordPress Blocks and Elements Adding Box Shadows to WordPress Blocks and Elements Mar 09, 2025 pm 12:53 PM

Adding Box Shadows to WordPress Blocks and Elements

Create a JavaScript Contact Form With the Smart Forms Framework Create a JavaScript Contact Form With the Smart Forms Framework Mar 07, 2025 am 11:33 AM

Create a JavaScript Contact Form With the Smart Forms Framework

Create an Inline Text Editor With the contentEditable Attribute Create an Inline Text Editor With the contentEditable Attribute Mar 02, 2025 am 09:03 AM

Create an Inline Text Editor With the contentEditable Attribute

Working With GraphQL Caching Working With GraphQL Caching Mar 19, 2025 am 09:36 AM

Working With GraphQL Caching

Demystifying Screen Readers: Accessible Forms & Best Practices Demystifying Screen Readers: Accessible Forms & Best Practices Mar 08, 2025 am 09:45 AM

Demystifying Screen Readers: Accessible Forms & Best Practices

Making Your First Custom Svelte Transition Making Your First Custom Svelte Transition Mar 15, 2025 am 11:08 AM

Making Your First Custom Svelte Transition

Comparing the 5 Best PHP Form Builders (And 3 Free Scripts) Comparing the 5 Best PHP Form Builders (And 3 Free Scripts) Mar 04, 2025 am 10:22 AM

Comparing the 5 Best PHP Form Builders (And 3 Free Scripts)

File Upload With Multer in Node.js and Express File Upload With Multer in Node.js and Express Mar 02, 2025 am 09:15 AM

File Upload With Multer in Node.js and Express

See all articles