vue3.2结合element-plus自定义上传组件

感觉el-upload自定义也没合适的文档,想自定义处理事件和处理文件的时候不方便。所以研究了一下。

首先给出基本操作:

javascript 复制代码
// vue中定义了上传的变量

const uploadFile = ref(null)

// 下面这个是可以显示具体有哪些操作
console.log(uploadFile.value)
uploadFile.value.abort(); // 取消上传
uploadFile.value.submit(); // 提交上传
uploadFile.value.clearFiles(); // 清空文件列表
uploadFile.value.handleStart(file); // 开始上传指定的文件
uploadFile.value.handleRemove(file); // 移除指定的文件

给出完整的代码:

javascript 复制代码
<template>
<el-scrollbar class="upload-file" min-size="100">
                    <el-upload
                        ref="uploadFile"
                        :multiple="true"
                        :on-change="handleChange"
                        :on-remove="handleRemove"
                        class="left-view"
                        :auto-upload="false"
                        accept=".gjf,.mol"
                    >
                      <template #trigger>
                        <el-button type="primary">选择文件</el-button>
                      </template>
                      <template #tip>
                        <div class="el-upload__tip text-red">
                        </div>
                      </template>
                    </el-upload>
                  </el-scrollbar>
</template>

<script setup>
import {ref} from 'vue'

const uploadFile = ref(null)
const handleChange = async (file, uploadFileRef) => {
  /*
  console.log(uploadFile.value)
  uploadFile.value.abort(); // 取消上传
  uploadFile.value.submit(); // 提交上传
  uploadFile.value.clearFiles(); // 清空文件列表
  uploadFile.value.handleStart(file); // 开始上传指定的文件
  uploadFile.value.handleRemove(file); // 移除指定的文件
  */
  const allowedExtensions = ['gjf', 'mol'];
  if (!allowedExtensions.includes(file.name.split('.')[1])) {
    ElMessage.error('只能上传Gjf或者mol格式的文件');
    // uploadFile.value.clearFiles()
    uploadFile.value.handleRemove(file);
  } else {
    // 保存文件内容
    fileList.push(file);
  }
}

watch(fileList, async (newVal, oldVal) => {
  // 等待500毫秒,以确保 fileList 变化稳定
  await new Promise(resolve => setTimeout(resolve, 500));
  // 清空 srcList 数组
  srcList.splice(0, srcList.length);
  // 使用 Object.keys() 遍历 fileList 的属性
  for (const key of Object.keys(newVal)) {
    const file = newVal[key];
    await showFileToImage(file);
  }
});


// 处理移除文件时候的操作
const handleRemove = async (file, fileList) => {
  let uid = file.uid
  const index = srcList.findIndex((file) => file.uid === uid);
  if (index > -1) {
    srcList.splice(index, 1);
  }
}
const showFileToImage = async (file) => {
  let reader = new FileReader();
  reader.readAsArrayBuffer(file.raw);
  return new Promise(resolve => {
    reader.onload = async function (event) {
      let image_data;
      if (file.name.split('.')[1].toLowerCase() === 'gjf') {
        // gjf转图片
        image_data = await ConvertFile2Image(reader.result, "gjf");
      } else if (file.name.split('.')[1].toLowerCase() === 'mol') {
        // mol转图片
        image_data = await ConvertFile2Image(reader.result, "mol");
      }
      let imageURL = 'data:image/png;base64,' + image_data.data.image_data;
      srcList.push({name: file.name, uid: file.uid, url: [imageURL]});
      resolve();
    };
  });
}
</script>
相关推荐
weixin_427771616 小时前
css加载顺序导致本地和线上样式不一致
前端·css
漂流瓶jz13 小时前
Webpack如何实现万物皆可import?loader的使用/配置/手写实践
前端·javascript·webpack
ZC跨境爬虫14 小时前
跟着 MDN 学CSS day_41:显式轨道、隐式网格与区域命名放置
前端·javascript·css·ui·交互
修己xj14 小时前
告别手动存图!这款叫 Fatkun 的浏览器插件,简直是素材收集神器
前端
袋鼠云数栈15 小时前
从前端到基础设施,ACOS 如何打通企业全链路可观测
运维·前端·人工智能·数据治理·数据智能
AskHarries15 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
Moment15 小时前
长上下文会最终杀死 Rag 吗?
前端·javascript·后端
qcx2316 小时前
【系统学AI】25 论文导读 ①:两篇改变 AI 的开山之作——Attention Is All You Need & ReAct
前端·人工智能·react.js·transformer
kyriewen17 小时前
大文件上传最全指南:分片、断点续传、秒传,一篇就够了
前端·javascript·面试
我叫黑大帅17 小时前
解决聊天页内部滚轮改为页面滚动问题
javascript·后端·面试