vue3 ElementPlus el-upload 图片列表缩略图模式添加查看大图 删除等自定义按钮

warning: 这篇文章距离上次修改已过180天,其中的内容可能已经有所变动。

在Vue 3和Element Plus中,可以通过自定义el-upload的列表项模板来实现自定义按钮和图片的查看、删除功能。以下是一个简化的例子:




<template>
  <el-upload
    list-type="picture-card"
    action="https://jsonplaceholder.typicode.com/posts/"
    :on-preview="handlePreview"
    :on-remove="handleRemove"
    :file-list="fileList"
  >
    <template #default="{ file }">
      <div class="image-container">
        <img :src="file.url" alt="" class="image-item"/>
        <span class="delete-button" @click="handleRemove(file)">X</span>
      </div>
      <div class="el-upload__text">上传照片</div>
    </template>
  </el-upload>
  <el-dialog :visible.sync="dialogVisible">
    <img :src="dialogImageUrl" alt="" style="display: block; max-width: 100%;" />
  </el-dialog>
</template>
 
<script setup>
import { ref } from 'vue';
import { ElUpload, ElDialog } from 'element-plus';
 
const fileList = ref([
  { name: 'food.jpg', url: 'http://placekitten.com/300/300' },
  // ...可以添加更多文件对象
]);
 
const dialogVisible = ref(false);
const dialogImageUrl = ref('');
 
const handlePreview = (file) => {
  dialogImageUrl.value = file.url;
  dialogVisible.value = true;
};
 
const handleRemove = (file) => {
  // 实现删除逻辑,例如从fileList中移除对应文件
  const index = fileList.value.indexOf(file);
  if (index !== -1) {
    fileList.value.splice(index, 1);
  }
};
</script>
 
<style scoped>
.image-container {
  position: relative;
  display: inline-block;
}
.image-item {
  width: 100px;
  height: 100px;
  object-fit: cover;
}
.delete-button {
  position: absolute;
  top: 0;
  right: 0;
  background-color: red;
  color: white;
  padding: 2px 5px;
  border-radius: 50%;
  cursor: pointer;
}
</style>

在这个例子中,我们使用el-upload组件的list-type属性设置为picture-card来展示缩略图,并通过template #default定义了自定义的列表项结构。在这个结构中,我们添加了一个图片和一个用于删除的按钮。点击图片会弹出查看大图的对话框,点击删除按钮会触发删除操作。

注意:这个例子中的删除操作只是简单地从fileList数组中移除文件对象,并没有进行真实的文件删除操作。在实际应用中,你需要根据后端API来实现删除文件的逻辑。

评论已关闭

推荐阅读

DDPG 模型解析,附Pytorch完整代码
2024年11月24日
DQN 模型解析,附Pytorch完整代码
2024年11月24日
AIGC实战——Transformer模型
2024年12月01日
Socket TCP 和 UDP 编程基础(Python)
2024年11月30日
python , tcp , udp
如何使用 ChatGPT 进行学术润色?你需要这些指令
2024年12月01日
AI
最新 Python 调用 OpenAi 详细教程实现问答、图像合成、图像理解、语音合成、语音识别(详细教程)
2024年11月24日
ChatGPT 和 DALL·E 2 配合生成故事绘本
2024年12月01日
omegaconf,一个超强的 Python 库!
2024年11月24日
【视觉AIGC识别】误差特征、人脸伪造检测、其他类型假图检测
2024年12月01日
[超级详细]如何在深度学习训练模型过程中使用 GPU 加速
2024年11月29日
Python 物理引擎pymunk最完整教程
2024年11月27日
MediaPipe 人体姿态与手指关键点检测教程
2024年11月27日
深入了解 Taipy:Python 打造 Web 应用的全面教程
2024年11月26日
基于Transformer的时间序列预测模型
2024年11月25日
Python在金融大数据分析中的AI应用(股价分析、量化交易)实战
2024年11月25日
AIGC Gradio系列学习教程之Components
2024年12月01日
Python3 `asyncio` — 异步 I/O,事件循环和并发工具
2024年11月30日
llama-factory SFT系列教程:大模型在自定义数据集 LoRA 训练与部署
2024年12月01日
Python 多线程和多进程用法
2024年11月24日
Python socket详解,全网最全教程
2024年11月27日