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

2019-06-04 17:44:14

参考地址 【VUE】图片预览放大缩小插件

第一种:viewerjs使用介绍

viewerjs插件截图

1、先安装依赖
npm install v-viewer --save

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

//main.jsimport 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>

viewerjs使用配置参数


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

vue-photo-preview插件截图


1、先安装依赖
npm install vue-photo-preview --save

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

//main.jsimport 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使用介绍

vue-picture-preview插件截图


1、先安装依赖
npm install vue-picture-preview --save

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

//main.jsiimport 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插件只有预览和切换上下张功能,另外两种都有放大和缩小(包括手势)以及其他功能。还是蛮好上手的插件,但我是更喜欢第一种




  • 2019-12-03 16:36:03

    跨域资源共享 CORS 详解

    阮一峰大哥的文章写的不错,推荐,也推荐他的整个王章,大家可以去看一下啊。

  • 2019-12-03 16:37:01

    去除options,减少options的访问

    因为跨域请求,浏览器可能(后面讲)会发送一次options请求,如果处理不好,跨域还是会gg的。 之前很少涉及跨域,涉及也是简单请求(下面阮老师文章中区别热简单请求和复杂请求),所以基本不会很少关注options。后面就遇到坑了,下面讲讲注意点。

  • 2019-12-04 10:46:26

    nuxt.js项目中全局捕获异常并生成错误日志全过程

     需求:客户在使用过程中页面报错时,可以生成错误记录传回服务器,以便改进。   步骤:     一.全局捕获异常,     二.发送到服务端,     三.生成错误日志。   一.全局捕获异常 如图,vue提供了errorHandle这个方法来处理全局异常,更多详细内容参见官网。

  • 2019-12-04 10:47:59

    nuxt.js项目中全局捕获异常并生成错误日志全过程

     需求:客户在使用过程中页面报错时,可以生成错误记录传回服务器,以便改进。   步骤:     一.全局捕获异常,     二.发送到服务端,     三.生成错误日志。   一.全局捕获异常 如图,vue提供了errorHandle这个方法来处理全局异常,更多详细内容参见官网。

  • 2019-12-04 10:48:18

    vue 项目资源文件 static 和 assets 不说区别直接使用?

    assets中资源会webpack构建压缩到你代码中,而static文件直接引用。 static 中长存放类包、插件等第三方的文件,assets里放属资源文件比如自己资源图片、css文件、js文件。 引入资源的方式static文件夹可以使用~/static/方式引入, assets文件夹可以使用 ~@/assets 方式引入

  • 2019-12-05 17:01:36

    Vue 结合 Axios 接口超时统一处理

    当网路慢的时候。又或者公司服务器不在内地的时候,接口数据请求不回来超时报错的情况相信大家肯定遇到过的,这里我把我公司项目请求超时的处理方法分享下,希望看过后有帮助。