Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Specifying different font-sizes for different font-families

Tags:

css

Is there a way to specify a different font-size for a different font-family. The font I want to use(for purposes of product branding) is a somewhat rare font (FlashDLig) not supported by all PC's and browsers. (my one windows 7 PC with IE 9 does not display it...) Now for a fallback font I use Arial, the problem is that arial is much larger than FlashDLig, so I want to specify a different font-size for it in the same class. Is it possible?

I know you can probably use font-size-adjust but it is only supported in Firefox.

Any suggestions? Javascript magic maybe?

Thanks

like image 809
Dexter Schneider Avatar asked Jun 13 '12 20:06

Dexter Schneider


1 Answers

I would recommend defaulting to Arial, and then create a second class that uses a @font-face declared for your font. Then I think you'd have to use Javascript to test whether the font was able to load (maybe check derived style of some element you put off-screen), and if so, change the class to the new one. The reason I'd do it that way instead of starting with your custom font has to do with the idea of progressive enhancement.

Here's one way to change the class in Javascript:

if (fontLoaded()) {
    document.body.className += " fontLoaded";
}

And then in your CSS:

@font-face {
    ... /* declare font face */
}
body {
    font-family: "Arial";
    font-size: 0.8em;
}
body.fontLoaded {
    font-family: "FlashDLig";
    font-size: 1em;
}
like image 72
Aidan Brumsickle Avatar answered Nov 15 '22 08:11

Aidan Brumsickle