The typography of bootstrap…
The bootstrap folks depend on Normalize CSS to, ahem, normalize font sizes. According to Harry Roberts of csswizardry.com, Normalize CSS is stating correctly, font-size:100%;
, making the default font size 16px. According to Brian Cray of pxtoem.com, 16px ≈ 12pt—which is very traditional for a default font size. Harry has plenty to say about my pre-bootstrap use of font-size:62.5%;
:
The main reason people reset the font-size to 10px is point one; to make maths easier. If your quasi-base is 10px and you want an actual base of 12px it’s simply 1.2em. The maths is easier, we can work with units of ten more easily, but that comes at the cost of maintainability.
The main reason, I feel, behind using the 62.5% method is laziness, and that’s a good thing. Good developers are lazy. However that laziness is misguided; it’s actually causing you more work. You have to define font-sizes on all elements rather than just once and letting them inherit and you have to tackle those horrible inheritance issues when an explicitly sized element is placed inside another one.
Brian Cray insists that (points per inch / pixels per inch) = (72pt / 96px)
which sounds right to me for Microsoft Windows (and maybe Linux); he also suggests to me that (96px / 16px) = 6em
. So, when Cray writes 16px * (72pt / 96px) = 12pt
, I can also assert that 72pt / 6em = 12pt / 1em
.
So, for font-size:100%;
, we have a relationship between em values (Xem
) and points values(Ypt
): Xem = (1em / 12pt) * Ypt
. The following table summarizes:
**Points** | **Ems** |
6pt | .5em |
7pt | .563em |
8pt | .625em |
9pt | .75em |
10pt | .813em |
11pt | .875em |
12pt | 1em |
14pt | 1.125em |
16pt | 1.313em |
18pt | 1.5em |
20pt | 1.667em |
22pt | 1.83em |
24pt | 2em |
26pt | 2.167em |
28pt | 2.333em |
36pt | 3em |
48pt | 4em |
72pt | 6em |
96pt | 8em |
Bootstrap encourages the use of font classes for sizing
The table above looks great and it suggests a clean, crisp relationship between ems and points. But I have found that fuzzy type and weird line-height problems (that can cause unwanted drop shadows in boxes with border radius) when I explicitly set small font sizes (below 1em). Moreover, setting these values can get in the way of the responsive intentions baked into the Bootstrap framework. The assumption here is that Bootstrap would rather have us use classes like .small
or .h4
to specify font size:
For de-emphasizing inline or blocks of text, use the
<small>
tag to set text at 85% the size of the parent. Heading elements receive their ownfont-size
for nested<small>
elements.You may alternatively use an inline element with .small in place of any
<small>
.