Lazy load images using Intersection Observer, apply progressive rendering and css animations.

License: MIT

Language: JavaScript

Keywords: javascript, lazy-loading, vue, web-performance


npm npm

A Vue.js component to lazy load an image automatically when it enters the viewport using the Intersection Observer API.

Do you know VueDose? It's where you can learn tips about the Vue.js ecosystem in a concise format, perfect for busy devs! 🦄



npm install v-lazy-image

Warning: You'll need to install the w3c Intersection Observer polyfill in case you're targeting a browser which doesn't support it.

You can register the component globally so it's available in all your apps:

import Vue from "vue";
import { VLazyImagePlugin } from "v-lazy-image";


Or use it locally in any of your components:

import VLazyImage from "v-lazy-image";

export default {
  components: {

You must pass an src property with the link of the image:

  <v-lazy-image src="" />

That image will be loaded as soon as the image enters the viewport.

Progressive Loading

You can use the src-placeholder property to define an image that is shown until the src image is loaded.

When the src image is loaded, a v-lazy-image-loaded class is added, so you can use it to perform animations. For example, a blur effect:


<style scoped>
.v-lazy-image {
  filter: blur(10px);
  transition: filter 0.7s;
.v-lazy-image-loaded {
  filter: blur(0);

You could listen to the intersect and load events for more complex animations and state handling:


@jmperezperez has written about the progressive loading technique on his blog, in case you want a deeper explanation.

Responsive Images

Using the srcset property you can set images for different resolutions:

    srcset="image.jpg 1x, image_2x.jpg 2x"

When using the srcset attribute is recommended to use also src as a fallback for browsers that don't support the srcset and sizes attributes:

    srcset="image-320w.jpg 320w, image-480w.jpg 480w"
    sizes="(max-width: 320px) 280px, 440px"

The srcset prop is combinable with src-placeholder in order to apply progressive loading.


If you want to wrap the img in a picture tag, use the prop usePicture. You can then use slots to add additional elements above the img element`.

  srcset="image-320w.jpg 320w, image-480w.jpg 480w"
  <source srcset="image-320w.jpg 320w, image-480w.jpg 480w" />

Renders as:

  <source srcset="image-320w.jpg 320w, image-480w.jpg 480w" />
  <img srcset="image-320w.jpg 320w, image-480w.jpg 480w" alt="Fallback"/>

Note you can use the picture polyfill.


Aside from the following API, you can pass any img attribute, such as alt, and they'll be added to the rendered <img> tag.

Fields marked as (*) are required.


Name Type Description
src String (*) Image src to lazy load when it intersects with the viewport
src-placeholder String If defined, it will be shown until the src image is loaded.
Useful for progressive image loading, see demo
srcset String Images to be used for different resolutions
intersection-options Object The Intersection Observer options object.


Name Description
intersect Triggered when the image intersects the viewport
load Triggered when the lazy image defined in src is loaded

Project Statistics

Sourcerank 7
Repository Size 127 KB
Stars 198
Forks 20
Watchers 2
Open issues 4
Dependencies 792
Contributors 10
Tags 10
Last updated
Last pushed

Top Contributors See all

Alex Jover Anthony Gore Aarón García Hervás Alessandro Giordo Andrey Nazarov Alejandro Narvaja José M. Pérez Alejandro Narvaja Flavio Corpa Maximilian

Packages Referencing this Repo

A Vue.js component to lazy load images using the Intersection Observer
Latest release 1.3.2 - Updated - 198 stars
A Vue.js component to lazy load images using the Intersection Observer
Latest release 1.2.2 - Published - 198 stars

Recent Tags See all

1.3.2 February 04, 2019
1.3.1 February 01, 2019
1.3.0 February 01, 2019
1.2.2 July 09, 2018
1.2.1 March 13, 2018
1.2.0 March 06, 2018
1.1.0 March 05, 2018
1.0.1 February 27, 2018
1.0.0 February 27, 2018
0.0.2 February 26, 2018

Something wrong with this page? Make a suggestion

Last synced: 2019-02-04 11:42:24 UTC

Login to resync this repository