随笔 - 28  文章 - 2  评论 - 1  阅读 - 25021

VUE3的学习和使用(四)用viewerjs插件实现图片预览

用viewerjs插件实现图片预览

// 安装依赖
"viewerjs": "^1.9.0"

在template里展示图片并设置点击事件

复制代码
<template>
  <ul id="img-area">
   <li v-for="(item,index) in imgList" :key="item.id">
       <button @click="previewImage(index)">
          <img :src="xxx" alt=""/>
       </button>
    </li>
  </ul>
</template>
复制代码

预览函数

复制代码
const previewImage = (index) => {
  const box = document.querySelector('#img-area');

  if (box) {
    const photoViewer = new Viewer(box, {
      inline: false, // 是否启用 inline 模式
      fullscreen: true, // 播放时是否全屏
      title: false, // 是否显示当前图片的标题
      toolbar: {  // 显示工具栏
       // 下面各种按钮1显示,0隐藏,可自定义按钮大小和点击事件
        zoomIn: 1, // 放大图片
        zoomOut: 1, //缩小图片
        oneToOne: 1, // 图片比例100%
        reset: 1, // 重置图片大小
        prev: 1, // 查看上一张图片
        play: 0, // 播放图片
        next: 1,// 查看下一张图片
        rotateLeft: 1,// 向左旋转图片
        rotateRight: 1,// 向右旋转图片
        flipHorizontal: 1,// 图片左右翻转
        flipVertical: 1, // 图片上下翻转
      },
      // 定义用于查看的图像的初始索引
      initialViewIndex: index, 
      // 每次关闭查看时触发 
      hide () {
        photoViewer.destroy();
      },
      // 每次关闭查看时触发,在hide之后 
      hidden () {
        photoViewer.destroy();
      },
      // 每次查看时触发
      show () {
        photoViewer.full();
      },
    });
    photoViewer.show();
  }
};
复制代码

 

posted on   blue_hl  阅读(2122)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 一文读懂知识蒸馏
· 终于写完轮子一部分:tcp代理 了,记录一下
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

点击右上角即可分享
微信分享提示