Usage
Add the
loading="lazy"
attribute to a<img>
element that you want to lazily load. You can also use the<picture>
element to lazily load images in different formats.Use the
data-src
ordata-srcset
attribute to specify the high-quality image.If you have a pre-generated blurry placeholder image, use the
src
attribute to specify it. Otherwise, you can use a BlurHash or ThumbHash to generate a placeholder image on the fly.
<!-- You can use the `<img>` tag -->
<img
loading="lazy"
src="blurry placeholder ..."
data-srcset="image.png"
data-sizes="auto"
>
<!-- … or the `<picture>` tag -->
<picture>
<source
type="image/webp"
data-srcset="image-320w.webp 320w, image-640w.webp 640w"
data-sizes="100w"
/>
<img
loading="lazy"
src="blurry placeholder ..."
data-src="lazy.jpg"
data-srcset="image-320w.jpg 320w, image-640w.jpg 640w"
data-sizes="auto"
/>
</picture>
TIP
Set data-sizes="auto"
to automatically calculate the sizes
attribute when using data-srcset
.
- In your frontend code, import the
lazyLoad
function from the library and call it:
import { lazyLoad } from 'unlazy'
// Lazily load all `img[loading="lazy"]` images
lazyLoad()
Auto Calculation of the sizes
Attribute
unlazy supports setting the sizes
attribute automatically, corresponding to the current size of your image – just set the value of data-sizes
to auto
.
The automatic sizes calculation uses the display width of the image.
<img
loading="lazy"
src="data:image/svg+xml, ..."
data-srcset="image-320w.jpg 320w, image-640w.jpg 640w"
data-sizes="auto"
>
When calling lazyLoad
, the library will automatically calculate the sizes
attribute for all images with data-sizes="auto"
.
Alternatively, you can use the autoSizes
function to calculate the sizes
attribute for all images with data-sizes="auto"
, without lazy loading the images.
To do so, import the autoSizes
function from the library and call it:
import { autoSizes } from 'unlazy'
// Automatically calculate the sizes attribute for all `img[data-sizes="auto"], source[data-sizes="auto"]` images, without lazy loading them
autoSizes()
Custom Selectors
You can customize the CSS selectors to target specific images by passing a CSS selector, a DOM element, a list of DOM elements, or an array of DOM elements to lazyLoad
and autoSizes
.
For example, if you want to target images with a data-custom-lazy
attribute, you can set the selector to img[data-custom-lazy]
:
import { lazyLoad } from 'unlazy'
lazyLoad('img[data-custom-lazy]')
INFO
The loading="lazy"
attribute is still required for the images to be lazy loaded.
Manually Loading Images
If you want to load an image before it enters the viewport, you can call the loadImage
function directly. It accepts a HTMLImageElement
as an argument.
Import the loadImage
function from the library and call it:
import { loadImage } from 'unlazy'
const coolImage = document.querySelector('.image-to-load-first')
// Trigger the load before the image enters the viewport
loadImage(coolImage)
TIP
Keep in mind that manually loading images might negatively affect the perceived performance, as it will force the full-quality image to load immediately, even if it's not visible on the viewport.