Using Google fonts with Remixjs, TailwindCSS and Fontsource
data:image/s3,"s3://crabby-images/0ef68/0ef68dde66e1c946418836e908515c93ec370731" alt="media.getImageUrl(post.image).altText"
This is the beginning of my Remix.js journey. I’ve decided that Next.js and I needed a break. Although I’ve read many of the complaints developers have about Next.js, that’s not why I decided to try Remix.js. I kept coming across articles where developers loved their experience with Remix.js. I also appreciate that Remix.js closely follows web standards.
Next.js can sometimes feel like a magic box, it does offer great features—one of the best being font optimization. This was the first question I asked myself when I opened up my VSCode editor. My goal was to mimic, as closely as possible, what the Next.js next/font module does: automatic self-hosting with no network requests. I’m open to discussing other methods, but below is what I ended up doing.
data:image/s3,"s3://crabby-images/aba6f/aba6ff6fd1267730747e02ad814d50f39a3334f6" alt=""
For grabbing fonts, I decided to use Fontsource. It has several advantages:
Performance: No network requests to Google’s CDN.
Version Locking: Google regularly updates its fonts, but with Fontsource, you can lock the version.
Privacy: Using Fontsource avoids Google tracking the usage of their fonts.
Offline Support: Fonts load even when you’re offline.
Additional Font Options: Fontsource supports more than just Google Fonts.
Since my first Remix.js project is to convert my portfolio website from Next.js, I wanted to continue using the two fonts I have there: Open Sans and Playfair Display.
data:image/s3,"s3://crabby-images/b9a87/b9a872e632f35331fcc9a253d3b969a06e8cb8aa" alt=""
data:image/s3,"s3://crabby-images/031a4/031a463a48e18a089ad12b40fb83d50674e75909" alt=""
To load the fonts on the front end, you need to add the following lines to your root.tsx file.
data:image/s3,"s3://crabby-images/426d1/426d1dbe85506c5fdbc50bbc4b90b76aa1033335" alt=""
To display the fonts with TailwindCSS, there are two approaches. I prefer to load them globally, so I don’t have to repeatedly specify them in the HTML class attribute. Since I like to use two font families—one for headings and another for paragraphs—I add the following to my tailwind.css file.
data:image/s3,"s3://crabby-images/476e7/476e723b1b044ead753d8009b11830c670d94dfc" alt=""
Alternatively, if you prefer to override the TailwindCSS configuration file and apply fonts directly to your HTML class attributes, you can configure the tailwind.config.ts file as follows:
data:image/s3,"s3://crabby-images/7f342/7f342089861431b57182bfbec028bb9acd5f7f4b" alt=""
You can then apply the fonts to your HTML class attributes.
data:image/s3,"s3://crabby-images/23730/23730be27dcf7a12914340ebd7b8b93d7693827c" alt=""
Whichever way you decide to configure the fonts, you will achieve your desired result.
data:image/s3,"s3://crabby-images/36220/36220a00a30d1e64df1c0e197ddc2fcaa09e69dd" alt=""
As I continue my journey to discover whether Remix.js is the right fit for me, I will keep writing about any interesting things I encounter. Hopefully, this will help someone else transitioning away from Next.js.