Skip to content

An Mobile-First image viewer for Vue3 / 一个移动端优先的 Vue3 图片预览插件

License

Notifications You must be signed in to change notification settings

SSShooter/img-vuer

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ae8367f · Mar 4, 2024
Nov 8, 2021
Sep 23, 2021
May 27, 2019
Sep 23, 2021
Nov 8, 2021
Nov 8, 2021
Sep 23, 2021
Nov 8, 2021
Mar 12, 2018
Sep 23, 2021
Sep 23, 2021
Sep 23, 2021
Sep 23, 2021
Mar 1, 2024
Mar 1, 2024
Sep 23, 2021
Mar 4, 2024
Sep 23, 2021

Repository files navigation

img-vuer

For Vue2: https://github.com/ssshooter/img-vuer/tree/legacy

An Mobile-First image viewer for Vue3

中文 README


  • 🙆‍♀️ Easy to use
  • 👉 Swipe gesture
  • 🔍 Zoom gesture
  • Now you can use thumbnail~
  • Gallery hide when the physical back button is pressed (android device only)
  • Fix blurry after using scale()
  • 💻 compatible with PC

Now you can use both Mobile and PC Browser 😆

live demo

or scan the QRcode

Install

npm i img-vuer3 --save

Usage

// import img-vuer and install
import gallery from 'img-vuer3'
import 'img-vuer3/dist/style.css'

app.use(gallery, {
  swipeThreshold: 150, // default 100
  isIndexShow: true, // show image index, default true
  useCloseButton: true, // trigger gallery close with close button, default true
  preload: true, // preload images in the same group, default true
  sliderBackgroundColor: 'rgba(0,0,0,0.6)',
  sliderZIndex: 1001,
})
<!-- add direact to <img> -->
<img v-gallery :src="..." />

<!-- group images -->
<img v-gallery:groupName :src="..." />
<img v-gallery:groupName :src="..." />
<img v-gallery:groupName :src="..." />

<!-- OR (dynamic bind) -->
<img v-gallery="'groupName'" :src="..." />

<!-- use thumbnail, new in 0.11.0 -->
<img v-gallery :src="thumbnailSrc" data-large="originSrc" />

<!-- trigger close gallery, new in 0.14.0 -->
<button @click="$imgVuer.close()">close</button>

API

api arg description
close() / close the viwer
onIndexChange() cb $imgVuer.onIndexChange((newVal, oldVal)=>{...})
onToggle() cb on close or on open $imgVuer.onToggle((newVal, oldVal)=>{...})
changeBGColor() color change the background color of viwer $imgVuer.changeBGColor('#fff')
next() / switch to next image $imgVuer.next()
prev() / switch to previous image $imgVuer.prev()
getCurrentIndex() / /

Development

npm install

npm run dev

npm run build-lib

Troubleshooting

Abnormal page scale

Add meta

<meta
  name="viewport"
  content="width=device-width, initial-scale=1,user-scalable=0, maximum-scale=1"
/>

for a large number of large images

If you group a large number of large images, img-vuer will load all image in the same group, so it will cause unnecessary mobile data traffic and slow the page down.

You can use preload option in this situation and img-vuer will only load the image you watched.

key

Should not use index as key for the component which is added v-gallery.

License

MIT