关于element-ui组件库的el-image组件在大图预览时,需要展示图片的同时展示图片名称,点击上一页,下一页时需要动态获取图片的名称,以及在点击不同下标图片时,需要展示当前下标的图片的需求。

概要

关于element-ui组件库的el-image组件在大图预览时,需要展示图片的同时展示图片名称,点击上一页,下一页时需要动态获取图片的名称,以及在点击不同下标图片时,需要展示当前下标的图片的需求。(以下为个人思路,大佬请略过)

注意事项

注意:由于我的业务场景是在表格里面,需要点击图片文字预览图片,并且数据没有返回图片名称,所以我需要对图片名称进行处理。

解决思路

首先,当用户点击图片时,有三种情况。分别是当用户点击的为第一张图片时,当用户点击的第X张图片时,当用户点击的是和上一次点击时的图片。
其次,要对点击大图预览时,添加照片的名称
最后,预览时点击翻页按钮,需要动态获取图片的名称。

相关代码

src为传过来的图片地址,index为下标。

		<template slot-scope="{ row, $index }">
            <el-image
              style="width: 0px; height: 0px"
              class="hideImgDiv"
              :ref="`preview${$index}`"
              fit="contain"
              lazy
              :preview-src-list="srcList2"
            >
            </el-image>
            <span
              class="fileName"
              style="cursor: pointer"
              @click="clickImage(row.generateImgPath, $index)"
              >{{ row.generateImgPath | splitName }}</span
            >
          </template>
clickImage(src, index) {
      let name = src.split("/").pop();
      if (this.lastMovedIndex === index) {
        // 如果上一次已经移动过这个索引,则不执行任何操作
        this.$nextTick(async () => {
          let el = "preview" + index;
          await this.$refs[el].clickHandler();
          let oldDom = document.getElementsByClassName(
            "el-image-viewer__actions"
          )[0];
          let newDom = document.createElement("span");
          console.log("name", name);
          let newContent = document.createTextNode(name);
          newDom.appendChild(newContent);
          oldDom.appendChild(newDom);
          let next = document.getElementsByClassName(
            "el-image-viewer__next"
          )[0];
          let prev = document.getElementsByClassName(
            "el-image-viewer__prev"
          )[0];
          next.addEventListener("click", function () {
            let imgDiv = document.getElementsByClassName(
              "el-image-viewer__canvas"
            )[0];
            let imageUrl = imgDiv.getElementsByTagName("img")[0].src;
            let imageName = imageUrl.split("/").pop();
            let imgTitle = oldDom.getElementsByTagName("span")[0];
            imgTitle.innerText = imageName;
          });
          prev.addEventListener("click", function () {
            let imgDiv = document.getElementsByClassName(
              "el-image-viewer__canvas"
            )[0];
            let imageUrl = imgDiv.getElementsByTagName("img")[0].src;
            let imageName = imageUrl.split("/").pop();
            let imgTitle = oldDom.getElementsByTagName("span")[0];
            imgTitle.innerText = imageName;
          });
        });
        return;
      }
      if (index === 0) {
        // 当索引为0时,不改变数组
        this.srcList2 = this.srcList;
        this.lastMovedIndex = index; // 更新上一次移动的索引
        this.$nextTick(async () => {
          let el = "preview" + index;
          await this.$refs[el].clickHandler();
          let oldDom = document.getElementsByClassName(
            "el-image-viewer__actions"
          )[0];

          let newDom = document.createElement("span");
          console.log("name", name);
          let newContent = document.createTextNode(name);
          newDom.appendChild(newContent);
          oldDom.appendChild(newDom);
          let next = document.getElementsByClassName(
            "el-image-viewer__next"
          )[0];
          let prev = document.getElementsByClassName(
            "el-image-viewer__prev"
          )[0];
          next.addEventListener("click", function () {
            let imgDiv = document.getElementsByClassName(
              "el-image-viewer__canvas"
            )[0];
            let imageUrl = imgDiv.getElementsByTagName("img")[0].src;
            let imageName = imageUrl.split("/").pop();
            let imgTitle = oldDom.getElementsByTagName("span")[0];
            imgTitle.innerText = imageName;
          });
          prev.addEventListener("click", function () {
            let imgDiv = document.getElementsByClassName(
              "el-image-viewer__canvas"
            )[0];
            let imageUrl = imgDiv.getElementsByTagName("img")[0].src;
            let imageName = imageUrl.split("/").pop();
            let imgTitle = oldDom.getElementsByTagName("span")[0];
            imgTitle.innerText = imageName;
          });
        });
        return;
      }
      if (index >= this.srcList.length) {
        return;
      }
      // 将索引之前的元素移动到数组末尾
      const beforeIndex = this.srcList.slice(0, index);
      const afterIndex = this.srcList.slice(index);
      this.srcList2 = afterIndex.concat(beforeIndex);
      this.lastMovedIndex = index; // 更新上一次移动的索引
      this.$nextTick(async () => {
        let el = "preview" + index;
        await this.$refs[el].clickHandler();
        let oldDom = document.getElementsByClassName(
          "el-image-viewer__actions"
        )[0];

        let newDom = document.createElement("span");
        console.log("name", name);
        let newContent = document.createTextNode(name);
        newDom.appendChild(newContent);
        oldDom.appendChild(newDom);
        let next = document.getElementsByClassName("el-image-viewer__next")[0];
        let prev = document.getElementsByClassName("el-image-viewer__prev")[0];
        next.addEventListener("click", function () {
          let imgDiv = document.getElementsByClassName(
            "el-image-viewer__canvas"
          )[0];
          let imageUrl = imgDiv.getElementsByTagName("img")[0].src;
          let imageName = imageUrl.split("/").pop();
          let imgTitle = oldDom.getElementsByTagName("span")[0];
          imgTitle.innerText = imageName;
        });
        prev.addEventListener("click", function () {
          let imgDiv = document.getElementsByClassName(
            "el-image-viewer__canvas"
          )[0];
          let imageUrl = imgDiv.getElementsByTagName("img")[0].src;
          let imageName = imageUrl.split("/").pop();
          let imgTitle = oldDom.getElementsByTagName("span")[0];
          imgTitle.innerText = imageName;
        });
      });
    },

小结

希望大家永无BUG!!!🐱‍🚀🎉

  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
1. 首先,在项目中安装element-ui和axios: ``` npm install element-ui axios --save ``` 2. 在main.js中引入element-ui和axios: ``` import Vue from 'vue' import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' import axios from 'axios' Vue.use(ElementUI) Vue.prototype.$axios = axios ``` 3. 在组件中使用上传组件: ``` <template> <div> <el-upload class="avatar-uploader" action="/api/upload" :show-file-list="false" :on-success="handleSuccess" :before-upload="beforeUpload" > <img v-if="imageUrl" :src="imageUrl" class="avatar"> <i v-else class="el-icon-plus avatar-uploader-icon"></i> </el-upload> </div> </template> ``` 4. 在组件中定义上传前和上传成功的方法: ``` <script> export default { data() { return { imageUrl: '' } }, methods: { beforeUpload(file) { const isJPG = file.type === 'image/jpeg' const isPNG = file.type === 'image/png' if (!isJPG && !isPNG) { this.$message.error('只能上传jpg或png格式的图片') return false } const isLt2M = file.size / 1024 / 1024 < 2 if (!isLt2M) { this.$message.error('上传的图片大小不能超过2MB') return false } return true }, handleSuccess(response) { this.imageUrl = response.data.url } } } </script> ``` 5. 在服务器端,需要接收上传的图片,并将其保存到指定路径: ``` const express = require('express') const multer = require('multer') const path = require('path') const app = express() const storage = multer.diskStorage({ destination: function (req, file, cb) { cb(null, path.join(__dirname, '/public/images')) }, filename: function (req, file, cb) { const extname = path.extname(file.originalname) cb(null, Date.now() + extname) } }) const upload = multer({ storage: storage }) app.post('/api/upload', upload.single('file'), (req, res) => { const url = `http://localhost:3000/images/${req.file.filename}` res.json({ code: 0, data: { url: url } }) }) app.listen(3000, () => { console.log('server is running at http://localhost:3000') }) ``` 以上就是在Vue中使用element-ui的上传组件上传图片的方法。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值