search ]

What are Core Web Vitals & How to Improve Them?

Optimizing user experience is the key to success for every website on the internet. Whether you’re a business owner, marketer, or developer, Core Web Vitals can help you enhance the experience on your site and identify opportunities for improvement.

Core Web Vitals is an initiative by Google that provides unified guidelines for signals representing quality that are essential for a better and more accurate user experience on the web.

Over the years, Google has provided various performance measurement tools. Some of these tools are used by proficient developers, while others may struggle to keep up with the tools and metrics available in this context.

As Google aims to make it possible for website owners to understand user experience quality on their site without being performance experts, this initiative simplifies the landscape for those site owners and helps them focus on the most important metrics. These metrics are the same Core Web Vitals.

Core Web Vitals - LCP, INP & CLS

Core Web Vitals – LCP, INP & CLS

Page Experience Signals

The focus on the user and how well they are served by search results led Google to emphasize an additional aspect beyond content – this aspect being the user experience that visitors to your site encounter.

These same Page Experience Signals represent a set of metrics unrelated to the content quality on the site and are used by Google to evaluate the user experience (UX) of a specific site.

Page Experience Signals - Core Web Vitals

Page Experience Signals – Core Web Vitals

The metrics described in the image include (among others):

  • Loading
  • Interactivity
  • Visual Stability
  • Mobile Friendliness
  • Safe Browsing
  • HTTPS (Connection Encryption)

The first three of these metrics are known as Core Web Vitals and will join others on the list (already in use today) as metrics that will affect site ranking in search results starting from May 2021.


How to Improve Your Core Web Vitals Scores?

Core Web Vitals are not just a generic definition for UX metrics that Google considers when assessing the quality of a website. They are also a set of metrics with detailed explanations of how they are measured, what values are considered good, values that require improvement, or metrics that are not good.

1. Loading: Largest Contentful Paint (LCP)

The final loading time of a site does not represent a reliable universal value in the context of user experience, as most of the page is usually below the critical upper part of the page (BelowTheFold), which is not visible without scrolling.

The LCP indicator measures the perceived loading speed. Its value is the time it takes to load the largest text block or graphical element in the critical upper part of the page (AboveTheFold).

The LCP score evaluation is as follows:

  • Good LCP score: Under 2.5 seconds.
  • Needs improvement LCP score: Between 2.5 and 4 seconds.
  • Poor LCP score: Above 4 seconds.
LCP score evaluation - Core Web Vitals

LCP score evaluation – Core Web Vitals

Here is more information about Largest Contentful Paint (LCP).

How to Improve LCP Score?

The following optimization tasks will have an impact on the LCP scores your site receives:

  • Optimize server response time.
  • Improve TTFB.
  • Optimize images.
  • Optimize fonts.
  • Optimize CSS styles.

Check out the detailed post I’ve written about what LCP is and how to improve your LCP score.

2. Interactivity: Interaction to Next Paint (INP)

Loading and rendering a site is one thing, but getting the site ready for interaction is another. INP, just like LCP, relates to the speed of the site. It measures the time it takes for a page to respond to a user action, such as clicking a button.

The INP score evaluation is as follows:

  • Good INP score: Under 200ms.
  • Needs improvement INP score: Between 200ms and 500ms.
  • Poor INP score: Above 500ms.
INP score evaluation - Core Web Vitals

More information about Interactivity: Interaction to Next Paint (INP).

How to Improve INP Score?

The following optimization tasks will have an impact on the INP scores your site receives:

  • Reduce the impact of third-party code.
  • Reduce the runtime of JavaScript code on the site.
  • Reduce the number of HTTP requests to the server and, in general, reduce the site’s weight (traffic volume).

More information about INP optimization can be found at the provided link. Additionally, note that certain tools like DevTools or Lighthouse might display a value of Total Blocking Time (TBT) instead of FID.

3. Visual Stability: Cumulative Layout Shift (CLS)

This is a metric of visual stability. You have likely encountered the frustrating situation where you intend to click an option in a menu, move your mouse pointer to the desired place, and just before clicking, the menu shifts down, and a large banner appears in its place, “stealing” your click.

CLS is a concept for measuring the total value of sudden changes, those Layout Shifts of elements on a page while the page loads or is displayed.

The CLS score evaluation is as follows:

  • Good CLS score: Less than 0.1.
  • Needs improvement CLS score: Between 0.1 and 0.25.
  • Poor CLS score: Above 0.25.
CLS score evaluation - Core Web Vitals

CLS score evaluation – Core Web Vitals

Note that unlike the other two metrics, the CLS score is not measured over time but is presented as an absolute number. More information about Visual stability: Cumulative Layout Shift (CLS).

How to Improve CLS Score?

The following optimization tasks will impact the CLS scores your website receives:

  • Adding dimensions to image and video objects.
  • Saving space using CSS for elements that will be loaded.
  • Avoiding adding content above existing content after the DOM loads.
  • Preventing animations that shift the position of objects.

More information about optimizing CLS can be found at this link. Additionally, take a look at a more comprehensive post by Shai Toder that explains Cumulative Layout Shift (CLS) metric and ways to improve this score.

Lab Data vs Field Data

For each site’s Core Web Vitals, there are two sources of data:

  • Lab Data – Measurements made using special tools.
  • Field Data – Collected during visits by real users with Chrome browsers.

Lab Data is measured using the Chrome browser, Page Speed Insights, Web.dev, and also by the beloved WebPageTest.

You can measure and perform these measurements yourself using open-source code provided by Google.

On the other hand, Field Data is collected by Google specifically, as an average over the last twenty-eight days. You can obtain this data using the Chrome UX Report API – either by logging in or using PSI, Search Console, or even the CrUX API tool. Let’s take a look at some of these tools…


How to Measure the Values of Core Web Vitals?

As mentioned, Google provides documentation and a set of tools for testing LCP, FID, and CLS independently. Additionally, it offers free access to field data collected by thousands of users accessing your site with Chrome.

Google Search Console also provides data on the same Core Web Vitals. here is a new report called Page Experience that provides information in this context.

So, here are several ways to measure those metrics called Core Web Vitals:

1. Google’s Page Speed Insights Tool

Recently, the Page Speed Insights tool began displaying Core Web Vitals field data from the Chrome UX Report API, in addition to Lighthouse-based data. These are collected only for pages with substantial data.

Field Data - Page Speed Insights

If you’re interested in this topic, here’s a two-part series I wrote about Page Speed Insights.

2. WEB.DEV (Web)

web.dev, which is a kind of Google’s performance testing extension, also started displaying the same Core Web Vitals metrics. However, note that this tool displays only lab data, meaning those measured through tests from the Web.dev server.

Web.dev Lab Data

3. Google Search Console

From the website owner’s perspective, the appearance of Core Web Vitals data in Google Search Console seems to be the most useful. Under the Enhancements > Core Web Vitals section, results of LCP, FID, and CLS field data are shown.

Additionally, users have started receiving notifications from Search Console recently if there’s an issue with these metrics.

CLS Issue in Google Search Console

4. Chrome Developer Tools

In Chrome’s developer tools, you can check the Core Web Vitals in the Performance tab. There, you’ll get detailed information about the site’s performance, including those mentioned metrics. In the Experience section, you’ll find information about layout shifts (CLS), and in the Timing section, you’ll find the LCP value.

Chrome Dev Tools - Core Web Vitals

5. WebPageTest (WEB)

The best standalone tool for website performance testing is WebPageTest, acquired by Catchpoint in late 2020, and it started showing your Core Web Vitals data.

Besides displaying LCP, TBT, and CLS metrics, the tool provides a Filmstrip view, allowing you to observe a summarized animation of page loading with the option to highlight sudden layout changes.

Core Web Vitals Score - WebPageTest.org

I wrote a separate post about the amazing tool called WebPageTest. Take a look…

Summary

Around 2019, Google announced its intention to include site loading speed in its search engine ranking (which was implemented about a year later). Developers and site owners went into a frenzy during that period, focusing on improving site loading times.

Today, it’s unclear how much impact site loading speed has on its ranking in search results and SEO. Nevertheless, the positive impact of this announcement undoubtedly led to a better user experience on the Internet for all of us.

I hope this guide helped you understand these new metrics and how to use the tools at your disposal to measure and monitor them.

If you know of other tools that allow for the measurement of Core Web Vitals metrics, feel free to share in the comments…

Roee Yossef
Roee Yossef

I develop custom WordPress themes by design. I love typography, colors & everything between, and aim to provide high performance, seo optimized websites with a clean & semantic code.

0 Comments...

Leave a Comment

Add code using the buttons below. For example, to add PHP click the PHP button & add the code inside the shortcode. Typo? Please let us know...