Viewport Units
Learn about the CSS units related to the viewport.
What is a viewport?
The viewport is the visible area of a web page. It changes depending on the user’s device. It’s usually much smaller on mobile devices.
Before smartphones and tablets, web pages were only designed for computer screens, and it was common for them to have a fixed size.
Now, we often use smartphones and tablets to browse the internet, so fixed-size web pages are far too large to fit on these smaller screens. Flexible layouts are the solution to this!
CSS viewport units are a great way to get started with flexible layouts, which we’ll look at in detail in this lesson.
Viewport units
The vw
unit
The viewport width (vw
) unit represents a percentage of the user’s viewport width:
.element {
width: 20vw;
}
So, 20vw
is equal to 20% of the viewport’s width.
It’s similar to percentage, but the value remains consistent regardless of the value held by the parent elements. This is similar to how rem
units remain relative to the root.
These vw
units are often used for sizing responsive types, which is the type that adjusts its size based on the user’s screen size.
The vh
unit
The viewport height unit represents a percentage of the user’s viewport height
. So, 20vh
equals 20% of the height of the viewport:
.element {
width: 20vh;
}
This is the same as vw
, but it’s based on height instead.
The vmin
unit
The viewport minimum (vmin
) unit is the minimum value between the height or width as a percentage. This value is whichever is currently smaller, vw
or vh
. So, 10vmin
is 10% of the current width or height, depending on which one is smaller.
.element {
width: 10vmin;
}
The vmax
unit
The viewport maximum (vmax
) unit is the maximum value between the height or width, and it’s given as a percentage. It’s the opposite of vmin
, and is whichever value is currently larger, vw
or vh
. So, 20vmax
is 20 of the set width or height (whichever is larger):
.element {
width: 20vmax;
}
Which unit should you use?#
You can determine the most appropriate CSS unit by answering the following questions:
- Do you want this element to scale when the viewport size changes?
- If yes, what do you want it to scale relative to?
When you’ve answered these questions, determining the most appropriate unit is much simpler!
Example
Get hands-on with 1300+ tech skills courses.