A previewable image Vue component based on viewerjs.
⚠️ TIPS: Currentvue-previewable-imageneeds Vue verison to3.2.0+. For vue2, please use 1.x.
- See example here.
- Release Notes.
- ✔️ Support preview image via viewerjs.
- ✔️ Support image lazy load.
- ✔️ Support using image viewer as a component via ImageViewer.
| Version | Support Vue version | Docs | 
|---|---|---|
| ^1.7.0+ | ^2.7.14 | See v1 | 
| ^2.1.2+ | ^3.2.0and above | See v2 | 
# pnpm
$ pnpm add vue-previewable-image
# yarn
$ yarn add vue-previewable-image
# npm
$ npm i vue-previewable-imageDo not forgot to import the style
vue-previewable-image/dist/style.css
<template>
  <main>
    <PreviewableImage
      v-model:current-preview-index="currentIndex"
      :src="src"
      :preview-src-list="srcList"
      :viewer-title="viewerTitle"
      width="100px"
      @switch="handleSwitch"
    />
  </main>
</template>
<script setup lang="ts">
import { ref } from 'vue'
import { PreviewableImage } from 'vue-previewable-image'
import type { CustomViewerTitle, ViewerSwitchEvent } from 'vue-previewable-image'
const src =
  'https://fuss10.elemecdn.com/e/5d/4a731a90594a4af544c0c25941171jpeg.jpeg'
const srcList = [
  'https://fuss10.elemecdn.com/8/27/f01c15bb73e1ef3793e64e6b7bbccjpeg.jpeg',
  'https://fuss10.elemecdn.com/1/8e/aeffeb4de74e2fde4bd74fc7b4486jpeg.jpeg',
]
const viewerTitle: CustomViewerTitle = (img, { index, total }) => {
  console.log('img:', img)
  return `${img.alt} (${index + 1}/${total})`
}
const handleSwitch: ViewerSwitchEvent = (index, viewer) => {
  console.log('on switch:', index, viewer)
}
const currentIndex = ref(0)
</script>
You also can use viewerjs from this package, This is equal to import Viewer from 'viewerjs'.
import { Viewer } from 'vue-previewable-image'Or, you can using image viewer as a component, See ImageViewer.
// main.ts
import { createApp } from 'vue'
import App from './App.vue'
import PreviewableImage from 'vue-previewable-image'
import type { PreviewableImageOptions } from 'vue-previewable-image'
const app = createApp(App)
app.use(PreviewableImage, {
  // set global component name
  componentName: 'PreviewableImage',
  // set Viewer default options
  defaultViewerOptions: {
    // ...
  }
} as PreviewableImageOptions).mount('#app')| Prop name | Description | Type | Available value | Default value | 
|---|---|---|---|---|
| width | The img container width | string | - | undefined | 
| height | The img container height | string | - | undefined | 
| src | The srcof img | string | - | undefined | 
| alt | The altof img | string | - | undefined | 
| referrerPolicy | The referrerPolicyof img | string | - | undefined | 
| lazy | Whether to enable image lazy load | boolean | - | true | 
| zIndex | Define the CSS z-indexvalue of the viewer in modal mode | numberorstring | - | 2015 | 
| fit | The object-fitof img | string | fill / contain / cover / none / scale-down | fill | 
| previewSrcList | Define your previewable image list | string[]or{ src: string; alt: string}[] | - | [] | 
| currentPreviewIndex | Current preview image shown index, support v-model | number | - | 0 | 
| viewerOptions | Define viewerjs Options | - | - | {} | 
| viewerTitle | Define viewer title. First argument is HTMLImageElementwhich is generated bypreviewSrcList, second argument is a object{ index: number; total: number }which record current viewer index and previewable image count | Function | - | undefined | 
| Event name | Description | Callback arguments | 
|---|---|---|
| switch | Emit when preview image switch. | (index: number, viewer: Viewer) => void | 
| load | Emit when image load success. | (e: Event) => void | 
| error | Emit when image load error. | (e: Event) => void | 
| Name | Description | 
|---|---|
| placeholder | Define the placeholder content to display when image is not loaded | 
| error | Define the content to display when image load error |