在Ant Design Vue 中使用图片预览的插件

在package.json中 安装 viewerjs

样式部门代码

复制代码
        <!-- 图片显示区域 - 使用Viewer.js -->
        <template slot="images" slot-scope="text, record">
          <div class="image-container">
            <div class="image_list" :id="'image-group-' + record.id">
              <div v-for="(img, index) in text" :key="index" class="imageInfo">
                <img :src="fixImageUrl(img)" class="image_item" />
              </div>
            </div>
            <div v-if="!text || text.length === 0" class="no-image">无图片</div>
          </div>
        </template>

Js部分代码

复制代码
 data() {
    return {
      viewerInstances: {}, // 存储Viewer实例
 // 表格列配置
      columns: [
        {
          title: "图片",
          dataIndex: "images",
          scopedSlots: { customRender: "images" },
          width: 400,
        },
          ]
   }
}

methods 方法部分

复制代码
 methods: {
    /**
     * 初始化Viewer.js实例
     */
    initViewers() {
      // 销毁现有的Viewer实例
      this.destroyAllViewers();

      // 为每个图片组创建Viewer实例
      this.orderData.forEach((item) => {
        if (item.images && item.images.length > 0) {
          const container = document.getElementById(`image-group-${item.id}`);
          if (container) {
            this.viewerInstances[item.id] = new Viewer(container, {
              toolbar: {
                zoomIn: 1, // 放大
                zoomOut: 1, // 缩小
                oneToOne: 1, // 1:1比例
                prev: 1, // 上一张
                next: 1, // 下一张
              },
              movable: true, // 允许拖拽图片
              zoomable: true, // 允许缩放
              rotatable: true, // 允许旋转
              scalable: true, // 允许拉伸
              transition: true, // 切换图片时使用过渡动画
              fullscreen: true, // 支持全屏
              keyboard: true, // 支持键盘操作(如箭头键切换图片)
            });
          }
        }
      });
    },

    /**
     * 销毁所有Viewer实例
     */
    destroyAllViewers() {
      Object.keys(this.viewerInstances).forEach((key) => {
        if (this.viewerInstances[key]) {
          this.viewerInstances[key].destroy();
        }
      });
      this.viewerInstances = {};
    },
}

最终效果

相关推荐
竹林81820 小时前
用Viem替代ethers.js:从一次签名失败到完整迁移的实战记录
前端·javascript
之歆20 小时前
DAY08_CSS浮动与行内块布局实战指南(上)
前端·css
light blue bird20 小时前
主子端台二分法任务汇总组件
前端·数据库·.net·桌面端winform
不可能的是21 小时前
Claude Code 子 Agent 机制全解:怎么跑起来、怎么被管理、怎么互不干扰
javascript
jeffwang21 小时前
我做了个让 AI 看屏幕跑测试的工具,因为 Playwright 测不了我的 Flutter Web
前端
HSunR21 小时前
dify 搭建ai作业批改流
开发语言·前端·javascript
代码不加糖1 天前
2026 跨境电商独立站实战:从 0 到 1 搭建高转化 SaaS 商城(附源码)
开发语言·前端·javascript
亲亲小宝宝鸭1 天前
拖一拖控件,拖出个问卷(低代码平台)
前端·低代码
江南十四行1 天前
ReAct Agent 基本理论与项目实战(一)
前端·react.js·前端框架
We་ct1 天前
LeetCode 72. 编辑距离:动态规划经典题解
前端·算法·leetcode·typescript·动态规划