Loading Fonts
π
Loading fonts is similar to loading images. It does come with unique challenges, though. How to know what font formats to support? There can be up to four font formats to worry about if you want to provide first class support to each browser.
The problem can be solved by deciding a set of browsers and platforms that should receive first class service. The rest can use system fonts.
You can approach the problem in several ways through webpack. You can still use the type
loader field as with images. Font test
patterns tend to be more complicated, though, and you have to worry about font file related lookups.
Setting up a loader
π
If you exclude Opera Mini, all browsers support the .woff format based on Can I Useβ. .woff2, is widely supported by modern browsers and is another option. Going with one format, you can use a similar setup as for images and rely on maxSize
:
const config = {
test: /\.woff2?(\?v=\d+\.\d+\.\d+)?$/, // Match .woff?v=1.1.1.
type: "asset",
parser: { dataUrlCondition: { maxSize: 50000 } },
};
In case you want to make sure the site looks good on a maximum amount of browsers, you can use type: "asset/resource"
field at a loader definition and forget about inlining. Again, it’s a trade-off as you get extra requests, but perhaps it’s the right move.
Here you could end up with a loader configuration as below:
const config = {
test: /\.(ttf|eot|woff|woff2)$/,
type: "asset/resource",
};
The way you write your CSS definitionβ matters. To make sure you are getting the benefit from the newer formats, they should become first in the definition.
@font-face {
font-family: "Demo Font";
src: url("./fonts/df.woff2") format("woff2"), url("./fonts/df.woff")
format("woff"),
url("./fonts/df.eot") format("embedded-opentype"), url("./fonts/df.ttf")
format("truetype");
}
Using icon fonts
π
iconfont-webpack-pluginβ was designed to simplify loading icon based fonts. It inlines SVG references within CSS files.
To include only the icons that are only needed, use fontmin-webpackβ.
Using Google Fonts
π
@beyonk/google-fonts-webpack-pluginβ can download Google Fonts to webpack build directory or connect to them using a CDN.
Manipulating file-loader output path and publicPath
π
publicPath
To have more control over font output, one option is to use url-loader and file-loader as they still work. Furthermore, it’s possible to manipulate publicPath
and override the default per loader definition. The following example illustrates these techniques together:
{
// Match woff2 and patterns like .woff?v=1.1.1.
test: /\.woff2?(\?v=\d+\.\d+\.\d+)?$/,
use: {
loader: "url-loader",
options: {
limit: 50000,
mimetype: "application/font-woff",
name: "./fonts/[name].[ext]", // Output below ./fonts
publicPath: "../", // Take the directory into account
},
},
},
limit
option. The loader options are passed to it. You can override the behavior by using the fallback
option.
Eliminating unused characters
π
subfontβ is a tool that performs static analysis against webpack’s HTML output and then rewrites the fonts to include only glyphs that are used. The subsetting process can reduce the size of the font files dramatically.
Generating font files based on SVGs
π
If you prefer to use SVG based fonts, they can be bundled as a single font file by using webfonts-loaderβ.
Conclusion
π
Loading fonts is similar to loading other assets. You have to consider the browsers you want to support and choose the loading strategy based on that.
To recap:
- When loading fonts, the same techniques as for images apply. You can choose to inline small fonts while bigger ones are served as separate assets.
- If you decide to provide first class support to only modern browsers, you can select only a font format or two and let the older browsers to use system level fonts.
In the next chapter, you’ll learn to load JavaScript using Babel and webpack. Webpack loads JavaScript by default, but there’s more to the topic as you have to consider what browsers you want to support.