百变鹏仔-专注前端行业精选
elementui多选上传 before-upload 格式效验错误总会触发before-remove (elementui多选上传on-success只执行了一次,只上传成功了一条)
作者:鹏仔先生日期:2024-01-19 17:14:05浏览:1752分类:JavaScript
今天鹏仔项目中使用elementui做一个批量上传附件时,遇到了以下问题,那么顺便分享一下解决方案。
问题
通过elementui的 :before-upload="beforeAvatarUpload" (上传文件之前的钩子)
beforeAvatarUpload(file) { const isJPG = file.type === 'image/jpeg'; const isJPG2 = file.type === 'image/jpg'; const isPNG = file.type === 'image/png'; const isPNG2 = file.type === 'image/bmp'; const isPDF = file.type === 'application/pdf'; const isLt5M = file.size / 1024 / 1024 < 5; if (!isJPG && !isJPG2 && !isPNG && !isPNG2 && !isPDF) { this.$message.warning('只支持bmp、jpg、png、pdf格式'); return Promise.reject(isJPG || isJPG2 || isPNG || isPNG2 || isPDF); } if (!isLt5M) { this.$message.warning('请上传5MB以内的文件!'); return Promise.reject(isLt5M); } this.loading = true; return (isJPG || isJPG2 || isPNG || isPNG2 || isPDF) && isLt5M; },
当上传文件为其他格式,效验格式错误时,总会触发 :before-remove="beforeRemove" (删除文件之前的钩子)
beforeRemove(file, fileList) { return this.$confirm(`确定移除 ${ file.name }?`); },
解决方法
我们只需在 :before-remove="beforeRemove" 事件时判断下当前文件是否为成功的附件即可。
beforeRemove(file, fileList) { if(file && file.status == 'success'){ return this.$confirm(`确定移除 ${ file.name }?`); } },
还有个问题,就是多选文件上传成功时 :on-success="handleAvatarSuccess" (文件上传成功时的钩子) 此方法只会执行一次,多个文件只push到了一条数据。
网上说是把 return false 改为 return Promise.reject(false) 但是我尝试了,还是不起作用!
最终方案如下所示(等所有上传请求完成后,再给fileList进行push赋值)
handleAvatarSuccess(res, file, fileList){ if(fileList.every(it => it.status == 'success')) { fileList.map(item => { item.response && this.fileList.push({name:item.name,url:item.response.data,fileName:item.name,fileUrl:item.response.data}); }) } }
手机扫码访问
猜你还喜欢
- 11-01 vue中实现代码高亮
- 08-09 vue动态修改网站的icon图标
- 07-08 VUE中ECharts提示框tooltip自动切换
- 07-03 网页中生成微信小程序二维码
- 07-02 微信小程序判断是安卓还是苹果
- 06-28 vue实现表格自动滚动功能 vue-seamless-scroll
- 04-19 VUE实现点击复制
- 04-16 vue将页面生成图片 vue生成海报
- 04-16 vue路由切换滑动效果 vue页面跳转交互 vue实现动画跳转
- 04-16 table固定表头和列 css实现表格固定表头
- 04-07 vue跳转页面清除历史记录,页面跳转删除历史记录
- 02-22 VUE You are using the runtime-only build of Vue where the template compiler is not available. Either
取消回复欢迎 你 发表评论:
- 搜索
- 随机tag
暂无评论,来添加一个吧。