位置: IT常识 - 正文

Vue中使用的el-upload时批量上传图片时报错问题处理(vue中el-dialog)

编辑:rootadmin
Vue中使用的el-upload时批量上传图片时报错问题处理 项目场景:

推荐整理分享Vue中使用的el-upload时批量上传图片时报错问题处理(vue中el-dialog),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue el-,vue中el的作用,vue中el-dialog,vue中el-col,vue el-,vue中el的作用,vue中el的作用,vue中el-dialog,内容如对您有帮助,希望把文章链接给更多的朋友!

项目场景:项目中有一个文件上传的场景,使用el-upload组件进行上传,单图上传是正常,但是在进行批量上传时报了错。

问题描述

使用el-upload在进行多图批量上传时系统提示报错。 报错提示:

Uncaught TypeError: Cannot set properties of null (setting 'status')     at VueComponent.handleProgress (element-ui.common.js:29656:1)     at Object.onProgress (element-ui.common.js:29373:1)     at XMLHttpRequestUpload.progress (element-ui.common.js:29039:1)

原因分析:Vue中使用的el-upload时批量上传图片时报错问题处理(vue中el-dialog)

在网上找了许多解决方案,有的说是因为el-upload组件file-list绑定的数组不可以手动修改,需要在on-success方法中使用另一个数组来存放文件,但实际操作下来还是有诸多问题,后来认真看了报错信息,思考是否跟文件上传时的状态有关。

在on-success方法中将fileList console.log出来

Success (res, file, fileList) {   console.log(fileList, 'fileList') }

发现当第一张上传完成时后面几张的status的值都为ready,是否在on-success中回传给file-list的值只取success状态下的呢?导致on-success只触发了一次,后面几张因为status问题而不往下执行了,于是决定使用every等所有图片状态都为success时再传值给file-list。

解决方案:

使用every等所有图片状态都为success时再传值给file-list

handleSuccess (res, file, fileList) { if (res.code == 200) { //参考如下代码即可 if (fileList.every(item => item.status == "success")) { //由于fileList是所有的文件包含之前已上传过的,这里需要做区分(带response的即为新上传的) fileList.map(item => { item.response && this.fileList.push({ name: item.name, fileId: item.response.data.name, url: item.response.data.url }); }) } this.$emit('input', this.fileList) } else { fileList.filter(o => o.uid != file.uid) this.$emit('input', this.fileList) this.$message({ message: res.msg, type: 'error', duration: 1500 }) } },

 最后效果如下:

本文链接地址:https://www.jiuchutong.com/zhishi/288828.html 转载请保留说明!

上一篇:灯光璀璨的曼哈顿下城,美国纽约 (© New York On Air/Offset/Shutterstock)(灯光璀璨的夜晚)

下一篇:【今日七夕】Love locker on a red stripe hanging in a temple in Chengdu, China © Philippe LEJEANVRE/Getty Images(今日七夕祝福语)

  • 增值税发票认证在哪里
  • 个人所得税既有租房又有房贷
  • 个人独资企业生活费用和经营费用混在一起的
  • 吴中区个体户如何办理
  • 含税价和不含税计算公式
  • 两年前的发票可以补开吗
  • 等线补交以前年度附加税会计分录
  • 财务报告与财务报表的联系与区别
  • 普通发票作废要本人去拿吗
  • 一般纳税人取得3%专票可以抵扣吗
  • 保险柜库存现金留存不能超过多少
  • 工程款先开票
  • 关于公司食堂的文案
  • 增值税开票金额在哪里看
  • 发票是不是一定要三签才能开
  • 主办会计和会计助理的区别
  • 财政总预算会计分为三级
  • 个人投资者
  • 农产品加工所得税
  • 个人出租房屋给公司可以开专票吗
  • 个体户生产所得税怎么计算
  • 生产成本可以结转到其他业务成本吗
  • 在线网速测试网站测速工具
  • 外观专利的价值
  • multiple editions是什么版本
  • 企业支付宝收到钱到哪里
  • 股东已转让股权还可以追究出资吗
  • php生成代码
  • laravel with查询指定字段
  • php 图片水印
  • 建筑工程合同生效的条件有哪些?
  • 土地使用税计入管理费用还是税金及附加
  • 产品出库单附在什么凭证后面
  • 这年头不好混图片
  • 模型怎么部署
  • es6 promise finally
  • 微信公众号开发用什么语言
  • 大小周是否违反劳动法
  • 拆迁补偿账务处理办法
  • python 子进程通信
  • mysqlbinlog -vvv
  • 织梦如何做提取卡密
  • 将织梦dedecms转换到wordpress
  • 含税与不含税的区别是什么
  • 发票认证后总局没信息
  • sql server索引怎么用
  • 新公司申请一般纳税人流程
  • sql文件压缩
  • 不动产租赁服务包括哪些
  • 所得税会计核算要点及程序有哪些
  • 会计支付预付款怎么记账
  • 个体户办营业执照网上怎么申请
  • 试算不平衡的原因是什么
  • 日常生活中各种形式的能量的转化
  • 财务费用在贷方表示增加还是减少
  • 佣金付给别人公司合法吗
  • 农民专业合作社是企业法人吗
  • 什么情况下应选用基轴制配合
  • 工程上第三方代表啥意思
  • 如何跨数据库查询
  • sql语句去除重复值
  • win10 build 21277
  • freebsd怎么样
  • linux中如何配置环境变量
  • windows 进度条
  • fsrec.sys
  • linux命令eof
  • linux如何更改文件夹权限
  • cocos2d-x2.2.3和android平台环境的搭建
  • 安装centos no such device
  • linux shell在while中用read从键盘输入的实现
  • shell中数组如何定义
  • Node.js与Sails redis组件的使用教程
  • unity怎么加人
  • jquery选择器的优势有哪些
  • jquery分页插件的使用
  • python引用和调用有什么不同
  • fragment
  • 云南税务局发票查询
  • 大东地税局
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设