【VUE】图片预览放大缩小插件

本文介绍了三种用于图片预览的Vue插件:viewerjs、vue-photo-preview及vue-picture-preview,详细展示了它们的安装、配置及使用方法。前两者提供丰富的功能如放大、缩小及手势操作,而vue-picture-preview则专注于基本的预览和切换功能。

在看项目时,突然看到预览图片的弹窗,感觉好僵硬,不能放大,不能切换,于是便在网上找下关于图片预览的插件,有找到三个插件,具体的优劣势的看自己的使用吧,我目前只是在电脑查看效果,分别是viewerjs插件、基于photoswipe的vue-photo-preview插件以及vue-picture-preview插件


第一种:viewerjs使用介绍

1、先安装依赖

npm install v-viewer --save

2、main.js内引用并注册调用

//main.js
import Viewer from 'v-viewer'
import 'viewerjs/dist/viewer.css'

Vue.use(Viewer);
Viewer.setDefaults({
  Options: { "inline": true, "button": true, "navbar": true, "title": true, "toolbar": true, "tooltip": true, "movable": true, "zoomable": true, "rotatable": true, "scalable": true, "transition": true, "fullscreen": true, "keyboard": true, "url": "data-source" }
});

3、代码中使用xxx.vue

<template>
    <div class="content">
        <h1>Viewer图片预览插件</h1>
        <viewer :images="imgs">
            <img v-for="src in imgs" :src="src.url" :key="src.title">
        </viewer>
   </div>
</template>
<script>
export default {
  data () {
    return {
      imgs: [
       {
          url: 'https://ss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=85690711,3884201894&fm=27&gp=0.jpg',
          title: '图片1'
        },
        {
          url: 'https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=3564877025,796183547&fm=27&gp=0.jpg',
          title: '图片2'
        }
      ]
    }
  },
}
</script>

第二种:vue-photo-preview使用介绍

1、先安装依赖

npm install vue-photo-preview --save

2、main.js内引用并注册调用

//main.js
import preview from 'vue-photo-preview'
import 'vue-photo-preview/dist/skin.css'
Vue.use(preview)

3、代码中使用xxx.vue

<template>
    <div class="content">
       <section>
        <h1>preview图片预览插件</h1>
        <img v-for="src in imgs" :src="src.url" :key="src.title" :preview="src.preview" :preview-text="src.title">
    </section>
   </div>
</template>
<script>
export default {
  data () {
    return {
      imgs: [
       {
          url: 'https://ss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=85690711,3884201894&fm=27&gp=0.jpg',
          title: '图片1',
          preview: '1'
        },
        {
          url: 'https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=3564877025,796183547&fm=27&gp=0.jpg',
          title: '图片2',
          preview: '1'
        }
      ]
    }
  },
}
</script>

option配置请查看 http://photoswipe.com/documentation/options.html

第三种:vue-picture-preview使用介绍

1、先安装依赖

npm install vue-picture-preview --save

2、main.js内引用并注册调用

//main.js
iimport vuePicturePreview from 'vue-picture-preview'
Vue.use(vuePicturePreview)

3、在根组件添加 lg-preview 组件的位置

<!-- APP.vue -->
<div id="app">
    <router-view></router-view>
    <lg-preview></lg-preview>
</div>

4、代码中使用xxx.vue

<template>
    <div class="content">
        <h1>vuePicturePreview图片预览插件</h1>
        <img v-for="(img,index) in imgs"
        v-preview="img.url"
        :src="img.url"
        :alt="img.title"
        :key="index"
        preview-title-enable="true"
        preview-nav-enable="true">
   </div>
</template>
<script>
export default {
  data () {
    return {
      imgs: [
       {
          url: 'https://ss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=85690711,3884201894&fm=27&gp=0.jpg',
          title: '图片1'
        },
        {
          url: 'https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=3564877025,796183547&fm=27&gp=0.jpg',
          title: '图片2'
        }
      ]
    }
  },
}
</script>

总结

这三个插件介绍完了,除了第三种vue-picture-preview插件只有预览和切换上下张功能,另外两种都有放大和缩小(包括手势)以及其他功能。还是蛮好上手的插件,但我是更喜欢第一种。

### Vue 移动端图片缩放插件 #### v-viewer 插件 对于 Vue.js 移动端项目而言,`v-viewer` 是一款强大的图片浏览组件,能够轻松实现图片预览和缩放功能。此插件不仅支持基本的图片展示,还提供了诸如旋转、缩放以及翻转等功能[^1]。 安装 `v-viewer` 可通过 npm 或 yarn 进行: ```bash npm install v-viewer --save ``` 或是 ```bash yarn add v-viewer ``` 接着,在 main.js 中引入并注册该插件: ```javascript import Viewer from 'v-viewer' import 'viewerjs/dist/viewer.css' Vue.use(Viewer); Viewer.setDefaults({ Options: {/* your global options */} }); ``` 最后,在模板内使用如下方式调用 viewer 功能: ```html <div> <img src="path/to/image.jpg" alt="" /> </div> <script> export default { mounted() { this.$nextTick(() => { let images = document.querySelectorAll('img'); this.$viewerApi({images}) }) } } </script> ``` #### vue-photo-preview 插件 另一个值得考虑的选择是 `vue-photo-preview`,这款插件专为解决移动端图片放大缩小而设计。为了使图片具备良好的放大效果,需给 `<img>` 标签添特定类名 `wc-perview-img`[^4]。 初始化设置类似于其他 Vue 组件的方式: ```bash npm i vue-photo-preview -S ``` 随后在应用入口处全局注册: ```javascript import PhotoPreview from "vue-photo-preview"; import "vue-photo-preview/dist/skin.css"; Vue.use(PhotoPreview, { /* 自定义配置 */ }); ``` 页面上则按照常规方法嵌入图像标签,并附所需样式类: ```html <img class="wc-perview-img" :src="imageUrl"/> ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值