Trevor Recommends
Codecrafters logo
I've been using Codecrafters to level up my coding skills by building Redis, Shell, Git, Kafka, SQLite from scratch. It's free to start and really helped me understand the internals. 40% off if you want the full experience.
Up to date
Published
3 min read

Trevor I. Lasn

Staff Software Engineer, Engineering Manager

Preloading Responsive Images

How to properly preload responsive images to improve initial page load

Responsive images and preloading don’t naturally work well together. When you use responsive images, the browser makes smart decisions about which image to load based on the device’s characteristics. But preloading needs to happen before these decisions can be made.

Here’s what a typical responsive image looks like:

The browser examines these srcset and sizes attributes to determine which image to download. It considers the viewport width, the device’s pixel density, the sizes attribute, and the available image widths. This smart selection process is what makes responsive images so powerful.

The common approach to preloading breaks down with responsive images.

This fails because it forces the browser to download a specific image variant without considering the responsive image selection logic. You might end up downloading the wrong size, wasting bandwidth and potentially hurting performance.

The Right Way: Responsive Preloading

Modern browsers support responsive preloading through imagesrcset and imagesizes attributes:

This approach tells the browser about all available image variants and how their widths should be calculated. The browser can then make the same smart decisions about which image to preload that it would make for a regular responsive image.

When working with modern image formats like WebP or AVIF, browser support becomes an important consideration:

The type attribute prevents browsers that don’t support AVIF from downloading these images. This same concept applies when working with multiple image formats in your responsive image markup:

You can verify your responsive preloading setup using the browser’s DevTools and Performance Observer API:

This code helps you monitor which image variants are being downloaded and how long they take, giving you concrete data about your preloading strategy’s effectiveness.

Web performance is a balancing act. While preloading responsive images can significantly improve load times, it’s crucial to implement it thoughtfully.

Consider preloading only your most critical responsive images, typically those that appear above the fold or contribute to your Largest Contentful Paint (LCP).

By combining responsive image preloading with modern image formats, you’ll deliver the optimal image variant to each user while ensuring it loads as quickly as possible.


Found this article helpful? You might enjoy my free newsletter. I share dev tips and insights to help you grow your coding skills and advance your tech career.

Interested in supporting this blog in exchange for a shoutout? Get in touch.


Liked this post?

Check out these related articles that might be useful for you. They cover similar topics and provide additional insights.

Webdev
3 min read

Form Validation That Doesn't Annoy Users: CSS :user-valid and :user-invalid

The new pseudo-classes :user-valid and :user-invalid give us a smarter way to style form validation states based on user interaction

Dec 12, 2024
Read article
Webdev
2 min read

link rel='modulepreload': Optimize JavaScript Module Loading

The rel='modulepreload' indicates that a module script should be fetched, parsed, and compiled preemptively, and stored for later execution

Dec 4, 2024
Read article
Webdev
5 min read

Add Auth to Astro 5 with Clerk in 5 Minutes

The simplest setup for adding Clerk authentication to your Astro project, with minimal code

Dec 18, 2024
Read article
Webdev
13 min read

10 Essential Terminal Commands Every Developer Should Know

List of useful Unix terminal commands to boost your productivity. Here are some of my favorites.

Aug 21, 2024
Read article
Webdev
4 min read

Mental Toughness is the Best Quality a Developer Can Have

Mental toughness gets developers through challenges like debugging, picking up new tools, and hitting tight deadlines. It’s about staying calm and pushing through when things get tough.

Sep 12, 2024
Read article
Webdev
5 min read

WebAssembly (Wasm): When (and When Not) to Use It

Understanding the real use cases for WebAssembly beyond the performance hype

Nov 25, 2024
Read article
Webdev
12 min read

Robust Data Fetching Architecture For Complex React/Next.js Apps

How I use the 'Three Layers of Data' architecture pattern for React and Next.js apps to avoid common pitfalls, tech debt, and improve performance

May 4, 2025
Read article
Webdev
8 min read

Invisible columns in SQL

It’s a small feature, but it can make a big difference.

Aug 26, 2024
Read article
Webdev
4 min read

HTTP CONNECT: Building Secure Tunnels Through Proxies

Understand how HTTP CONNECT enables HTTPS traffic through proxies

Nov 28, 2024
Read article

This article was originally published on https://www.trevorlasn.com/blog/preloading-responsive-images. It was written by a human and polished using grammar tools for clarity.