v-img is a plugin for Vue.js that allows you to show images in full-screen gallery by adding only one directive to the <img> tag.
| Firefox | Chrome | Safari | Opera | Firefox (mobile) | Chrome (mobile) | Safari (mobile) | 
|---|---|---|---|---|---|---|
| 32 | 44 | 9.1 | 32 | ✅ | ✅ | ✅ | 
 big thanks to
 
 
 Demonstration
 
npm install v-img --save
In your script entry point:
import Vue from 'vue'; import VueImg from 'v-img'; Vue.use(VueImg);
- make sure to change latestto the number of latest version of the plugin to avoid compatibility problems.
<!-- After vuejs --> <script src="https://cdn.jsdelivr.net/npm/v-img@latest/dist/v-img.min.js"></script>
*in this snippet all settings has its default value. No need to specify them unless you want to change default behavior. Unfortunately if you used CDN way to include plugin you can't set up these options, but still can set them up inline.
const vueImgConfig = { // Use `alt` attribute as gallery slide title altAsTitle: false, // Display 'download' button near 'close' that opens source image in new tab sourceButton: false, // Event listener to open gallery will be applied to <img> element openOn: 'click', // Show thumbnails for all groups with more than 1 image thumbnails: false, } Vue.use(VueImg, vueImgConfig);
Add v-img directive to the image.
<img v-img src="...">
Add similar directive arguments to place images to one gallery. (:name from the example below could be anything you want)
<img v-img:name src="..."> <img v-img:name src="...">
Options that could be specified in directive value
<img v-img="{...}" src="...">
| Option | Description | Default value | Data type | 
|---|---|---|---|
| group | The same as directive argument, but could be set dynamically | directive argument or undefined | string | 
| src | Image source that will be displayed in gallery | src attribute value from html tag | string | 
| title | Caption that will be displayed | empty string or value of the altattribute, ifaltAsTitleis true | string | 
| openOn | Event listener to open gallery will be applied to <img>. Available options are 'dblclick', 'mouseover' and all native JS events. | 'click' if another not stated when initializing plugin | string | 
| sourceButton | Display 'download' button near 'close' that opens source image in new tab | falseifsourceButtonis not set to true when initializing plugin | boolean | 
| thumbnails | When opening group by clicking (or other openOnevent) on this image, thumbnails of images for this group will be visible | falseifthumbnailsis not set to true when initializing plugin | boolean | 
| opened | Function that will be executed on gallery open | undefined | function | 
| closed | Function that will be executed on gallery close | undefined | function | 
| changed(imageIndex) | Function that will be executed when switching between images in gallery | undefined | function | 
| cursor | Cursor when hovering original <img> | 'pointer' | string | 
- Any of these options except opened,closed,changedfunctions andopenOnproperty could be changed at runtime.