vue3实现文件夹上传及存在问题解决

需求是使用 VUE3 实现上传文件夹,其功能主要依赖于 <input> 标签的属性 webkitdirectory

html 复制代码
<input
  ref="uploadFolderRef"
  type="file"
  style="display: none"
  @change="submitUpload"
  webkitdirectory
  multiple
/>
<el-button @click="openUploadDialog">上传文件夹</el-button>

将 input 标签的 display 属性设为 none 使其隐藏起来,后续通过点击按钮触发上传框的点击事件:

javascript 复制代码
import { ref } from 'vue'
import { ElMessage } from 'element-plus'

const uploadFolderRef = ref()

const openUploadDialog = () => {
  uploadFolderRef.value.click()
}

const submitUpload = (e: any) => {
  const files = Array.from(e.target.files)
  
  Promise.all(
    files.map((file: any) => {
      const form = new FormData()
      form.append('file', file)
      return UploadApi.upload(form)
    }),
  )
    .then(() => {
      ElMessage.success('上传成功')
    })
    .catch(() => {
      ElMessage.error('上传失败')
    })
}

存在问题:重复上传相同文件夹,只有第一次有效,后续选择文件夹无法完成上传。

原因 是上传框的提交上传是 onchange 事件,选择相同的文件夹的 value 属性值是一样的,因此无法触发;

解决方案

  1. 手动修改上传框的 value 属性为空;

    javascript 复制代码
    const uploadFolderRef = ref()
    /* 打开上传框之前,先将上传框的value属性设为空 */
    const openUploadDialog = () => {
      uploadFolderRef.value.value = ''
      uploadFolderRef.value.click()
    }
  2. 采用 JavaScript 生成上传框,这样将每次都生成新的上传框;

    html 复制代码
    <template>
        <el-button @click="createFileInput">上传文件夹</el-button>
    </template>
    
    <script setup lang="ts">
    const createFileInput = () => {
      const input = document.createElement('input')
      input.style.display = 'none'
      input.type = 'file'
      input.multiple = true
      input.webkitdirectory = true
      input.onchange = submitUpload
      document.body.appendChild(input)
      input.click()
    }
    </script>
相关推荐
小白小白从不日白6 分钟前
react 组件通讯
前端·react.js
罗_三金16 分钟前
前端框架对比和选择?
javascript·前端框架·vue·react·angular
Redstone Monstrosity23 分钟前
字节二面
前端·面试
东方翱翔30 分钟前
CSS的三种基本选择器
前端·css
Fan_web1 小时前
JavaScript高级——闭包应用-自定义js模块
开发语言·前端·javascript·css·html
yanglamei19621 小时前
基于GIKT深度知识追踪模型的习题推荐系统源代码+数据库+使用说明,后端采用flask,前端采用vue
前端·数据库·flask
千穹凌帝1 小时前
SpinalHDL之结构(二)
开发语言·前端·fpga开发
冯宝宝^1 小时前
基于mongodb+flask(Python)+vue的实验室器材管理系统
vue.js·python·flask
dot.Net安全矩阵1 小时前
.NET内网实战:通过命令行解密Web.config
前端·学习·安全·web安全·矩阵·.net
叫我:松哥1 小时前
基于Python flask的医院管理学院,医生能够增加/删除/修改/删除病人的数据信息,有可视化分析
javascript·后端·python·mysql·信息可视化·flask·bootstrap