Length
data:image/s3,"s3://crabby-images/d96fc/d96fc5661d1500d92cb2c248c75581deb5e36683" alt="Understanding CSS Length Units: px, em, rem, %, vw, vh"
The length refers to the size of elements in HTML and CSS. There are many ways to set lengths. In this section, we'll explain six key lengths which are frequently used in CSS. We'll explain sizing-related CSS properties in more detail in the next chapter.
px
px
(pixel) is used to define the length of elements in absolute pixel size. px is not dependent on the root element (HTML element), the parent element, or the viewport size; px
can be useful when you want to fix the size of elements regardless of the browser's viewport size.
data:image/s3,"s3://crabby-images/63aa4/63aa4e7a560d9152eefc9e0bd7467581c8e9025f" alt="pixel illustration pixel illustration"
em
em
defines the length of elements relative to the font size of the parent element. em
is usually used to define font size. When the parent's font size changes, the font size defined in em
will change proportionally. Due to this dependency, em
is used in the specific design element that you want to keep in proportion to the parent element. For usual cases, rem
is more commonly used for font size settings.
data:image/s3,"s3://crabby-images/61f98/61f986c3a91652aa12cb0387e2c14c4ce405bb4f" alt="How the em unit works to set length How the em unit works to set length"
rem
rem
defines the length relative to the font size of the root html element. rem
is usually used to define font size. As rem
is independent of the parent element, managing font size with rem
can be simpler than managing font size with em
because rem
does not require creating many font size variations in the same HTML document. Thus, rem
is preferred for font size setting.
data:image/s3,"s3://crabby-images/d1dc4/d1dc4856efe84904ef1cc5ea90f7af606cb8a6b9" alt="How the rem unit works to set length How the rem unit works to set length"
%
%
is used to define the length of elements relative to the parent element. %
is often used for layout sizing.
data:image/s3,"s3://crabby-images/77373/7737318cdc5264d10824fbc946c218a8400a1adb" alt="How the percent unit works to set length How the percent unit works to set length"
vw and vh
vw
(view width) and vh
(view height) are used to define the length of elements relative to the browser's viewport size. Viewport is the area where a browser renders web content like shown in the illustration below.
data:image/s3,"s3://crabby-images/b3eae/b3eae87ca50757cc4d623a0be6cd96040d9104fc" alt="How the vw and vh units work to set length How the vw and vh units work to set length"
100vw
and 100vh
are the same size as the browser's viewport size. 50vw
or 50vh
is 50% of the viewport width or viewport height respectively. As the sizes defined by vw
or vh
dynamically change depending on viewport size, vw
and vh
are used for responsive design.
data:image/s3,"s3://crabby-images/17ceb/17ceb09f36bfaf43f70c9368418322d6d989cdfc" alt="UI examples of an element with the vw and vh UI examples of an element with the vw and vh"