@unlazy/vue
The Vue integration provides an UnLazyImage component for your Vue application.
Installation
Install the @unlazy/vue package using your favorite package manager:
pnpm add -D @unlazy/vueyarn add -D @unlazy/vuenpm install -D @unlazy/vueLocal Import
Import the UnLazyImage component in your Vue single file component and use it in your template:
<script setup lang="ts">
import { UnLazyImage } from '@unlazy/vue/components'
</script>
<template>
<UnLazyImage
blurhash="LKO2:N%2Tw=w]~RBVZRi};RPxuwH"
src-set="image-320w.jpg 320w, image-640w.jpg 640w"
auto-sizes
/>
</template>Global Registration
If you prefer to make the UnLazyImage component globally available, you can register it in your main.ts file across your entire Vue application:
// src/main.ts
import Unlazy from '@unlazy/vue'
import { createApp } from 'vue'
import App from './App.vue'
const app = createApp(App)
app.use(Unlazy)
app.mount('#app')UnLazyImage Component
The UnLazyImage component allows you to easily implement unlazy in your Vue application, providing a smoother image loading experience. The component supports automatic calculation of the sizes attribute with the autoSizes prop. It also enables you to specify a blurhash for the blurry placeholder image.
Props
The UnLazyImage component accepts the following props:
| Prop | Type | Default | Description |
|---|---|---|---|
src | String | - | Image source URL to be lazy-loaded. |
srcSet | String | - | Image source set to be lazy-loaded. |
sources | Array | - | Array of UnLazySource objects to render a <picture> element. |
autoSizes | Boolean | false | Whether the sizes attribute should be automatically calculated. |
blurhash | String | - | A BlurHash string representing the blurry placeholder image. |
thumbhash | String | - | A ThumbHash string representing the blurry placeholder image. If both are provided, thumbhash takes precedence. |
placeholderSrc | String | - | Optional image source URL for a custom placeholder image. Ignored if a hash is provided. |
placeholderSize | Number | 32 | The size of the longer edge for BlurHash decoding. Ignored for ThumbHash. |
preload | Boolean | false | Whether the image should be preloaded immediately, bypassing lazy loading. |
loading | String | 'lazy' | Loading strategy for the image ('lazy' or 'eager'). |
The component also accepts all standard <img> HTML attributes via Vue's attribute inheritance.
Emitted Events
| Event | Payload | Description |
|---|---|---|
image-load | HTMLImageElement | Fired once when the real image finishes loading. |
image-error | HTMLImageElement, Event | Fired when the preload fails. |
INFO
Native @error listeners attach to the underlying <img> via Vue's attribute fallthrough and fire for both browser-level errors and the synthetic event unlazy dispatches when its preload fails. Reach for @image-error when you want the unwrapped element with a typed payload.
Reactivity
The component uses Vue's watchEffect to handle reactive updates:
- Automatically tracks changes to
src,srcSet, and hash props - Re-initializes lazy loading when relevant props change
- Cleans up previous listeners before setting up new ones
- Bypasses lazy loading entirely when
preloadistrue
Examples
<UnLazyImage
width="800"
height="600"
blurhash="LKO2:N%2Tw=w]~RBVZRi};RPxuwH"
src-set="image-320w.jpg 320w, image-640w.jpg 640w"
auto-sizes
/><UnLazyImage
width="800"
height="600"
thumbhash="1QcSHQRnh493V4dIh4eXh1h4kJUI"
src-set="image-320w.jpg 320w, image-640w.jpg 640w"
auto-sizes
/><UnLazyImage
width="800"
height="600"
placeholder-src="data:image/svg+xml, ..."
src-set="image-320w.jpg 320w, image-640w.jpg 640w"
auto-sizes
/>TIP
In each example, the sizes attribute is automatically calculated given the auto-sizes prop.
INFO
When using BlurHash, set explicit width and height attributes. See Hash-Based Placeholders for why.
Multiple Image Sources
Pass sources to render a <picture> element with format negotiation and art direction. Each entry becomes a <source> child:
<script setup lang="ts">
import type { UnLazySource } from 'unlazy'
import { UnLazyImage } from '@unlazy/vue/components'
const sources: UnLazySource[] = [
{ type: 'image/avif', srcSet: 'hero.avif 1x, hero@2x.avif 2x' },
{
media: '(max-width: 600px)',
srcSet: 'hero-mobile.jpg',
width: 480,
height: 640,
},
]
</script>
<template>
<UnLazyImage
src="/hero.jpg"
:sources="sources"
:width="640"
:height="427"
/>
</template>TIP
Set width and height per source to prevent layout shift when the breakpoint changes. Modern browsers use the matched <source>'s dimensions for the rendered <img>'s aspect ratio.
Preload Image
Useful if the UnLazyImage is part of e.g. a slider, and you want to preload the next image.
<template>
<UnLazyImage
:blurhash="blurhash"
src-set="image-320w.jpg 320w, image-640w.jpg 640w"
auto-sizes
preload
/>
</template>