Part of Series: CSS Handbook
CSS

CSS Fonts

📣 Sponsor

Fonts are the first things we see when we open a web page, and the type of font used on a web page gives us an idea of the style of content. Picking the right fonts, therefore, is a critical part of the web design process.

Fonts are well supported in CSS, and this section of the guide we'll be looking at how to manipulate fonts on a page.

It is pretty common for web developers and designers to use Google Fonts as a repository for adding fonts to their websites. If you do not add fonts to your website using font files like those provided by Google Fonts, then the only fonts available to the user will be the ones installed on their local computer.

Font Family

Probably the most useful font property to know, font-family lets you set the font for a specific element. It accepts a comma separated list of fonts. It is best practice to follow a list of fonts with a keyword, like sans-serif. That means if none of the fonts listed are installed, the system default sans-serif will be used.

div { font-family: 'Helvetica Neue', Arial, Helvetica, sans-serif; }

Note also that single word fonts do not require speech marks, but multi word fonts do. The keywords which can be used for font-family are:

  • serif - a font which has serifs, i.e. Times New Roman
  • sans-seri - a font which has no serifs, i.e. the font used on this page
  • monospace - a font with even spacing, for coding usually, i.e. Menlo
  • fantasy - a decorative font, i.e. Impact
  • cursive - a font which mimics handwriting, i.e. Apple Chancery

Font Size

A font size is set with font-size. This accepts any CSS unit, but the most common are pixels (px) or rem/em, which refers to the distance from the very top to the very bottom of the current font.

Usually, it is better practice to use em or rem.

div { font-size: 1.5rem; }

Font Style

In CSS, font-style refers to if a font is oblique or italic, both different styles of slanted fonts. It can be set to either of these values, or normal.

div { font-style: italic; }

I am italic!

Line Height

The height of a line of text can also be configured with CSS. To do this, we use line-height. As expected, this accepts any CSS unit, but the most common are:

  • no units - refers to the current font size, so 1 would be 16px for a 16px font, 2 would be 32px.
  • em/rem - as previously mentioned, refers to the font size.
  • px - the line height as defined in specific pixel units.
div { line-height: 1.5rem; } li { line-height: 1.25; }
Last Updated 1617479501777

More Tips and Tricks for CSS

Subscribe for Weekly Dev Tips

Subscribe to our weekly newsletter, to stay up to date with our latest web development and software engineering posts via email. You can opt out at any time.

Not a valid email