🎁 The Js-Craft Guide to React is now available with a 30% off discount!

Optimizing web fonts loading for CLS (Cumulative Layout Shift)

When we use external web fonts in our web pages we add a new network request that needs to be resolve to fully render the text. This can lead to a situation where the text changes position after the font is loaded. See the below picture.

This will happen if we import our fonts directly in the CSS files:

/* the wrong way */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:wght@400&family=Roboto:wght@300&display=swap');

We can improve this experience by importing the fonts in the head tag of the document.

<!-- do this instead -->
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Roboto:wght@100&display=swap" rel="stylesheet">

Note the rel="preconnect". Adding it will tell the browser to prioritize an early connection to that resource. However, this will mean that other requests will be delayed. So use preconnect with care.

We can go one sept forward by adding the text query param in the request URL of the web font. This will ensure that only the requested characters will be loaded, instead of the full set of characters in the web font. In our case, it will load only the H e l and o characters. More details here.

<!-- this is even better -->
<link rel="preconnect" href="https://fonts.gstatic.com">
<link href="https://fonts.googleapis.com/css2?family=Roboto:wght@100&display=swap&text=Hello" rel="stylesheet">

I have found out about this cool performance trick from this article written by Katie Hempenius and Una Kravets. Kudos to them!

10 Javascript AI projects with Langchain & React

Not sure what to build? Dive in with these Javascript AI projects! Learn how to build LLM powered apps using Langchain.js and React! Connect your apps to LLMs such as OpenAI, create agents, use vector databases, or setup AI context.

10 Javascript AI projects with Langchain & React

Not sure what to build? Dive in with these Javascript AI projects! Learn how to build LLM powered apps using Langchain.js and React! Connect your apps to LLMs such as OpenAI, create agents, use vector databases, or setup AI context.


Leave a Reply

Your email address will not be published. Required fields are marked *

📘 The Guide to React Home Screencasts Best of Newsletter Search X

📘 - 10 Javascript AI projects with React and LangChain

Hi friend! Before you go, just wanted to let you know about the 10 Javascript AI projects ideas with React and LangChain FREE ebook.

One of the best ways to learn is by doing the work. Choose from these 10 project ideas and start working on topics such as:

  • How does LangChain work
  • Connecting to OpenAI LLM
  • Create AI Agents
  • Simple and Sequential Chains
  • Adding Memory (Chat Context)
  • Prompt Templates
  • Using OutputParsers and Tools for Agents
  • Work with Documents and more...

Keep building and see the new capabilities LLM models can add to your React app! Get all projects as an ebook right to your inbox!

X