The Archive style sheets use ems to size text and most elements, and to specify margins and padding.
- What are ems?
- Ems and browser defaults
- Ems and the font-size property
- Ems and inheritance
- The standard scale in ems
- Resources
What are ems?
The em is a sliding measure. One em is a distance equal to the type size. In 6 point type, an em is 6 points; in 12 point type an em is 12 points and in 60 point type an em is 60 points. Thus a one em space is proportionately the same in any size. -Robert Bringhurst
Mr. Bringhurst is talking about ems in terms of points, a unit of measure more appropriate for print than screen. But ems are flexible, so Mr. Bringhurst’s explanation is equally true if we change from points to to pixels, which are the unit of measure web browsers use for text size:
In 6 pixel type, an em is 6 pixel; in 12 pixel type an em is 12 pixels and in 60 pixel type an em is 60 pixels. Thus a one em space is proportionately the same in any size.
Ems and browser defaults
The default font size on most web browsers is 16 pixels, which means the default size of 1em is 16 pixels. If the only declaration block in your stylesheet is p { margin: 2em 1em; }
, your paragraphs will have 16px text with a 32px margin at the top and bottom and a 16px margin at the left and right.
Of course, it’s possible to change a browser’s default settings. A visitor with a visual impairment might have their browser’s font size set to 20px. They’ll see the paragraphs with 20px text, 40px top and bottom margins, and 20px left and right margins – the same proportions as you, but in a size that works better for them.
Working with the browser default
To ensure that all browsers can properly display, resize, and zoom on our text, the first thing we do when working with ems is set the <body>
font size to 100%, or the default font size for the user’s web browser:
body {
font: 100%/1.125 'Lucida Grande', 'Lucida Sans Unicode', 'GNU Unifont', Verdana, Helvetica, sans-serif;
}
Ems and the font-size property
Ems aren’t just affected by the browser’s default font size. They’re also affected by the font sizes set in your stylesheet. For example, if you changed the declaration block from the previous section to p { font-size: 20px; margin: 2em 1em; }
, everyone would see 20px text with 40px top and bottom margins and 20px left and right margins.
However, we never use pixels to set font-size
in our stylesheeets. Doing so would override a visitor’s default browser settings. While we intended to make the paragraph text bigger than usual by setting it to 20px
, a visitor whose browser’s default is 24px will instead be seeing text that is smaller than usual.
Choosing a font-size
Instead of setting an absolute font size, ask yourself what you’re really trying to do. Are you trying to make the text bigger or smaller than it would normally be? In practice, this should depend on whether the text is more or less important than the main paragraph text. In the example above, we’re trying to make it bigger. How much bigger? If you divide the size you want the text to be (20px) by the size the text is (16px), you’ll find out how many ems your font-size
should be.
In this case, 20 divided by 16 gives us 1.25. Setting the font-size
of p
to 1.25em
will make the font bigger for everyone: 20px for anyone with a default of 16px, and 25px for anyone with a default of 20px.
There’s no need to adjust the margins. Browsers will recalculate margin: 2em 1em
based on the new font size, so the user who is now seeing 20px text will see 40px top and bottom margins while the user who is seeing 25px text will see 50px top and bottom margins – still twice the size of the text.
Ems and inheritance
An element’s em scale is also affected by the font size of its parent elements. What happens if a <p>
element with the style color: blue; font-size: 1.25em; margin: 2em 1em
is the child of a <div>
with the style color: green; font-size: 1.5em
?
We know that setting the child element’s color will override the parent’s and give us a paragraph of blue text, but ems work differently. The browser won’t ignore that font-size: 1.5em
from our div. Instead, it will apply the paragraph’s font-size: 1.25em
on top of it.
First, the browser will calculate the size of the div’s text to be 1.5 times the size of the default font. Then it will calculate the paragraph text to be 1.25 times the size of the div’s font size. So, a visitor with a default font size of 16px will see the div text at 24px and the paragraph text at 30px. The top and bottom margins would be 60px and the side margins would be 30px.
The standard scale in ems
The standard scale for font sizes is 8, 9, 10, 12, 14, 16, 18, 24, 36, 48, 60, 72. Assuming that most people are browsing with a default font size of 16px, let’s calculate how we would express those sizes in ems:
- 72/16 = 4.5em
- 60/16 = 3.75em
- 48/16 = 3em
- 36/16 = 2.25em
- 24/16 = 1.5em
- 18/16 = 1.125em
- 16/16 = 1em
- 14/16 = 0.875em
- 12/16 = 0.75em
- 10/16 = 0.625em
- 9/16 = 0.5625em
- 8/16 = 0.5em
- 6/16 = 0.375em
Our scale in ems
Almost all of the Archive’s content is inside #main, a div where the font size is set to 0.875em, which is 14px on web browsers with a default font size of 16px. This means that any element that is a direct child of <div id="main">
should have its em scale calculated as if 1em were equal to 14px. Here is how the standard font scale would be expressed in ems. Numbers have been rounded to three decimal places:
- 72/14 = 5.143em
- 60/14 = 4.286em
- 48/14 = 3.429em
- 36/14 = 2.571em
- 24/14 = 1.714em
- 18/14 = 1.286em
- 16/14 = 1.143em
- 14/14 = 1em
- 12/14 = 0.857em
- 10/14 = 0.714em
- 9/14 = 0.643em
- 8/14 = 0.571em
- 6/14 = 0.429em
- 5/14 = 0.375em
Margins and padding in the Archive em scale
It can be a bit difficult to get your head round using ems for margins and padding, so here are some tips:
- A single space (like between words) is approximately 0.25em.
- Since our font size in
#main
is0.875em/1.286
,margin: 0.643em auto;
gives you a single blank line (approximately 9px) between block elements. - Choosing values from the scale will automatically make your page look balanced.