As far as I know, one needs to use double or single quotes for fonts if they contain spaces, like:
font-family: "Times New Roman", Times; font-family: 'Times New Roman', Times;
But on Google Fonts (http://www.google.com/webfont), I also see
font-family: 'Margarine', cursive;
Some even use it like so:
font-family: 'Margarine', 'Helvetica', arial;
I find this weird, as the following works as well:
font-family: Arial, Helvetica, sans-serif; font-family: Cambria, serif;
So what is the correct usage of quotes around font names in CSS?
Quotes are recommended in the spec with "font family names that contain white space, digits, or punctuation characters other than hyphens". Quotes are required around font-family names when they are not valid CSS identifiers.
The font-family property specifies the font for an element. The font-family property can hold several font names as a "fallback" system. If the browser does not support the first font, it tries the next font.
Web authors should always add at least one generic family in a font-family list, since there's no guarantee that a specific font is installed on the computer or can be downloaded using a @font-face at-rule.
You can always put a specific font family name in quotes, double or single, so Arial
, "Arial"
, and 'Arial'
are equivalent. Only the CSS-defined generic font family names like sans-serif
must be written without quotes.
Contrary to popular belief, a font name consisting of space-separated names such as Times New Roman
need not be quoted. However, the spec recommends “to quote font family names that contain white space, digits, or punctuation characters other than hyphens”
font-family: Times New Roman; /* These are equivalent */ font-family: 'Times New Roman'; font-family: "Times New Roman"; font-family: Unique Ode™ 😊 Épopée; /* These are equivalent */ font-family: "Unique Ode™ 😊 Épopée"; font-family: "Answer #42" /* These are equivalent */ font-family: "Answer \23 42"; font-family: Answer \23 42;
As long as a font name contains only:
then quotes are optional. Single or double quotes. Case ignored. There are some weird edge cases: unquoted words must not start with a digit, dash-dash, or dash-digit.
font-family: "Intro Rust 2" /* Unquoted words must not start with numbers. */ font-family: "Serif"; /* For your own Serif, not the generic serif. */ font-family: "Yin/Yang"; /* Quote or code most ASCII punctuation. */
font-family: "Initial Seals JNL" /* `initial` and `default` are reserved words. */ font-family: "Omar Serif" /* Generic names might also be reserved words? */
font-family: monospace; /* Generic fonts must NOT be quoted. */ font-family: serif; font-family: sans-serif; font-family: cursive; font-family: fantasy;
Thanks:
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With