您的位置:首页 > 健康 > 养生 > vue3实现文件夹上传及存在问题解决

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

2024/10/10 4:06:41 来源:https://blog.csdn.net/fyx_demo/article/details/141761394  浏览:    关键词:vue3实现文件夹上传及存在问题解决

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

<inputref="uploadFolderRef"type="file"style="display: none"@change="submitUpload"webkitdirectorymultiple
/>
<el-button @click="openUploadDialog">上传文件夹</el-button>

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

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 属性为空;

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

    <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 = trueinput.webkitdirectory = trueinput.onchange = submitUploaddocument.body.appendChild(input)input.click()
    }
    </script>
    

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com