Just Creative

I’m Jacob Cass, the founder of JUST™ Creative. I’m a multi-disciplinary graphic designer, working with clients all around the world. My specialty is logo & brand identity design. JUST™ Get in touch.

Love


How to Use Custom Fonts with @font-face on WordPress

Posted on

This is a guest article by Matt Russell.

Using custom fonts is a fantastic way to help create a unique look for your site. There are currently a number of different methods for embedding fonts onto a website several of which rely on paid third party services.

This tutorial details how to use the @font-face expression on a WordPress site to embed a font stored locally rather than by any premium solution such as Typekit or Google Webfonts.

To keep things simple I will be using a fresh WordPress install with the default twentyeleven theme, though this method is applicable for any theme. This is how the site looks before changes have been made.

Wordpress Before

BEFORE: WordPress TwentyEleven Theme

1. Select A Font

I will be using the free Carbon Block font. With any free or premium font it is worth checking the terms and conditions to see if it is eligible for use on your site.

Carbon Black Font

Carbon Black Font

There is not currently a standardised file type for embeddable fonts across browsers with older versions of Internet Explorer using the proprietary .eot format and iPhones using .svg. Most modern browsers do support Web Open Font Format (WOFF) and TrueType (TTF) but to ensure that the widest possible variety of devices will display the font correctly, multiple formats need to be available.

2. Convert The Font to @Font-Face

It is possible to convert a font to all the needed formats yourself however it is far simpler to use Squirrels @font-face generator. This will convert your chosen font to all the formats needed and will generate the CSS code you will require.

Font Squirrel @font-face Generator

Font Squirrel @font-face Generator

You will need your chosen font in .ttf or .otf format. After adding your font to the generator with the “Add Fonts” button select optimal and tick the agreement. You will be able to download a .zip file with the font formats required, a .css file and an .html test file where you can check the font is being rendered correctly. The .css file will look something like below.

Font Squirrel Generated Code

Font Squirrel Generated CSS Code

This code is almost ready to use, font-family can be changed to whatever you would like the refer to the font as in the stylesheet, though leaving it as the font name can help avoid confusion if you start to use multiple custom fonts. The src is the location for the font which you may want to change, I will cover this later.

3. Upload Font Files To Your Site

The next step is uploading the font to your site, first make sure you backup the theme you will be to adding the font to. The four files you need to upload are the .eot, .svg, .woff, and .ttf formats from the downloaded .zip file. The fonts should be uploaded to the base directory of you chosen WordPress theme.

FileZilla File Upload

FileZilla File Upload

4. Edit Source Location

I have put the fonts in a folder named “fonts” folder to keep things neat, though this requires some changes to the @font-face code. “fonts/” has to be added to the beginning of each font location as in the example below.

Code Theme

Addition of fonts/ to the source.

5. Define Back-Up Fonts

The code can now be included in the beginning of the sites stylesheet and referenced as any standard font would be. It is important to include some additional fonts in case for some reason the browser is unable to display the local one.

CSS Header

Once included, the custom font should now display across a wide variety of browsers.

6. Custom Font Installation Complete

The Result: Custom Fonts

The Result: Custom Fonts

If you switch themes frequently but want to keep the font then you should upload the font files to the “/public_html” folder of your WordPress site. The new stylesheet will of course need to be updated with the @font-face code, with the difference being that the src uses an exact URL.

Do you have a preferred method for implementing custom fonts or know any other useful tools? Let us know in the comments.

This post was written by Matt Russell MD of WebHostingBuzz, who offer Shared, Reseller, and VPS web hosting services. You can follow them on Twitter @webhostingbuzz.

SUBSCRIBE: RSS, Email, Twitter, Facebook



12 JUST™ Creative Comments

  • Gord Grisenthwaite Reply

    Nicely put. One thing I have noticed is I tend to get better results with web fonts when I use absolute urls (http://www.domain.com/fonts/fontFamily/) to call fonts in my stylesheet. I collect all of my web fonts inside one folder on one of my websites and then point the stylesheet to the appropriate fonts.

    Also, Google Fonts provides over 500 free fonts and font families, and generates the necessary link and CSS snippets, providing a great introduction to using web fonts.

    A small drawback to loading web fonts is that there can be a few second delay before seeing the copy, as the browser gets the fonts.

  • FabioSG Reply

    good article, simple and well explained.

    i’m already using @font-face for some of the projects i’ve been working on, and i have to say that beside the few seconds delay Gord mentioned, i found yet another problem.

    Well it’s not exactly a problem but it keeps buging me… even though the font displays as expected, on firefox’s error console i keep geting an error:
    “downloadable font: download failed (@font-face { font-family: etc, etc…”

  • Fae Binkley Reply

    i’m already using @font-face for some of the projects i’ve been working on, and i have to say that beside the few seconds delay Gord mentioned, i found yet another problem.

  • Derrek Reply

    I’ve tried other tutorials to implement custom fonts on my website and yours is the first one to have actually worked! Thanks for this. It was really helpful and the perfect solution to a problem I’ve been facing for a week now.

    I love Open Sans and League Gothic and just had to have them on my site’s core design. :)

  • Toshiko Lessard Reply

    i’m already using @font-face for some of the projects i’ve been working on, and i have to say that beside the few seconds delay Gord mentioned, i found yet another problem.

  • Rasheeda Burrow Reply

    I’ve tried other tutorials to implement custom fonts on my website and yours is the first one to have actually worked! Thanks for this. It was really helpful and the perfect solution to a problem I’ve been facing for a week now.

  • sajjad Reply

    Good article, simple and well explained. Thanks for sharing.

  • Wen Fife Reply

    I love Open Sans and League Gothic and just had to have them on my site’s core design. :)

  • Paul D. Mitchell @ web consulting Reply

    Just wanted to say thanks for all the useful info. I really appreciated the breakdown of the code, that really helped me understand the process more clearly. Well done.

    Regards
    Paul

  • Lavette Gaylord Reply

    i’m already using @font-face for some of the projects i’ve been working on, and i have to say that beside the few seconds delay Gord mentioned, i found yet another problem.

  • Ana Hill Reply

    Thank you for your detailed and succinct instructions. Worked for me on the first go.


Submit A Creative Comment

Your email address will not be published. Required fields are marked *
Please use your real name and do not use keywords. All comments are moderated by myself and I reserve the right to edit or not publish your comment. Thank you!

You may use these HTML tags and attributes: <a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>



© Copyright JUST™ Creative 2007-2013. Designed by Jacob Cass. Powered by Wordpress using the Skeleton Framework. Fonts served by Typekit. Site hosted by (mt).