引用:https://www.jianshu.com/p/e449196a8d39
<el-upload
multiple
action=""
:limit="5"
:on-change="handleChange"
:on-remove="handleRemove"
:auto-upload="false"
:file-list="fileList"
:on-exceed="handleExceed"
>
<el-button slot="trigger" size="small" type="primary" @click="resetFileCount">选取文件</el-button>
<el-button size="small" type="success" @click="submitUpload">上传到服务器{{url}}</el-button>
</el-upload>
resetFileCount(){
this.fileCount = 0;
},
handleChange(file,fileList){
console.log("ccccccccccccccccccc",this.fileCount);
console.log("**********************************");
if (this.fileCount === 0){
this.oldFileList = Object.assign(this.fileList);
}
console.log(this.oldFileList,2222);
let isTrue = this.oldFileList.some((f)=>{
console.log(f.name,file.name);
return f.name === file.name})
if (isTrue){
this.$message.warning("请勿重复上传文件!")
fileList.pop()
return
}
this.fileList = fileList
this.fileCount++;
},
handleRemove(file,fileList){
this.fileList = fileList
},
submitUpload(){
if (this.fileList.length === 0){
this.$message.warning("请先选择上传文件!")
return
}
this.uploadFile()
},
uploadFile(){
let formData = new FormData();
this.fileList.forEach(file =>{
formData.append("multipartFiles",file.raw)
})
console.log(formData);
axios.post(this.url,formData,{"Content-Type":"multipart/form-data"})
},
dialogClose(){
this.$parent.closeAttachmentDialog()
},
handleExceed(){
this.$parent.handleExceed()
},
遇到的问题: 一次性上传多个文件时,他的on-change就会执行很多次,也会上传很多次。。上面的代码是自动上传的,也有判断文件个数是否等于 fileList 的长度是否相等,相等再上传。。。 一次性上传多个文件时,判断上传文件是否重复,设置一个fileCount 文件计数器 data:image/s3,"s3://crabby-images/2d1f4/2d1f4acb9eed11c0d136ec11c896e01ff4805b4b" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/2af22/2af221462d49fb52814605f37dcc2e815976e21e" alt="在这里插入图片描述" 每次选择文件的时候设置为0 ,将最初的fileList存起来 data:image/s3,"s3://crabby-images/2b2c1/2b2c1da918a4702700205f605e250bf45b808ecc" alt="在这里插入图片描述" 不然每一个文件都会执行on-change,都会初始化fileList,就不能根据fileList判断是否有这个文件
data:image/s3,"s3://crabby-images/0f73e/0f73e393a2a8dfb4d3dd78f27e752e9bf3cc297f" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/da2a7/da2a78a37dbf4d365c767b431c95ef62adb97a03" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/570ba/570ba63d314e5aeba24cda33952cbd875b507458" alt="在这里插入图片描述"
引用:https://blog.csdn.net/qq_42394457/article/details/96769170、https://blog.csdn.net/weixin_43915587/article/details/91953230
|