Lighthouse

This website is designed to help you understand and utilize the capabilities of the Lighthouse DevTool. Lighthouse is an open-source, automated tool for improving the quality of web pages. You can use it to audit performance, accessibility, progressive web apps, SEO, and more.

Throughout this course, we will explore various features of Lighthouse and demonstrate how to use them to enhance your web development skills. Each section will provide theoretical insights and hands-on exercises to ensure you gain practical experience.

User Flows in Lighthouse

Historically, Lighthouse has analyzed the cold pageload of a page. Starting in 2022 (Lighthouse v10), it can analyze and report on the entire page lifecycle via "user flows".

You might be interested in flows if…

In these cases, you want Lighthouse on a flow, not just a page load.

The three modes: Navigation, Timespan, Snapshot

Lighthouse can now run in three modes: navigations, timespans, and snapshots. Each mode has its own unique use cases, benefits, and limitations. Later, you'll create a flow by combining these three core report types.

Mode Use Cases Limitations
Navigation
  • ✅ Obtain a Lighthouse Performance score and all performance metrics.
  • ✅ Assess Progressive Web App capabilities.
  • ✅ Analyze accessibility immediately after page load.
  • 🤔 Cannot analyze form submissions or single page app transitions.
  • 🤔 Cannot analyze content that isn't available immediately on page load.
Timespan
  • ✅ Measure layout shifts and JavaScript execution time over a timerange including interactions.
  • ✅ Discover performance opportunities to improve the experience for long-lived pages and SPAs.
  • 🤔 Does not provide an overall performance score.
  • 🤔 Cannot analyze moment-based performance metrics (e.g. Largest Contentful Paint).
  • 🤔 Cannot analyze state-of-the-page issues (e.g. no Accessibility category)
Snapshot
  • ✅ Analyze the page in its current state.
  • ✅ Find accessibility issues deep within SPAs or complex forms.
  • ✅ Evaluate best practices of menus and UI elements hidden behind interaction.
  • 🤔 Does not provide an overall performance score or metrics.
  • 🤔 Cannot analyze any issues outside the current DOM (e.g. no network, main-thread, or performance analysis).

Web Vitals

Web Vitals is an initiative by Google to provide unified guidance for quality signals that are essential to delivering a great user experience on the web.

The Web Vitals initiative aims to simplify the landscape, and help sites focus on the metrics that matter most, the Core Web Vitals.

Core Web Vitals

Core Web Vitals are the subset of Web Vitals that apply to all web pages, should be measured by all site owners, and will be surfaced across all devtools. Each of the Core Web Vitals represents a distinct facet of the user experience, is measurable in the field, and reflects the real-world experience of a critical user-centric outcome.

To ensure you're hitting the recommended target for these metrics for most of your users, a good threshold to measure is the 75th percentile of page loads, segmented across mobile and desktop devices.

Largest Contentful Paint threshold recommendations Interaction to Next Paint threshold recommendations Cumulative Layout Shift threshold recommendations

Core Web Vitals

View Timings

On the Timings track, view important markers such as: