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)

在这里插入图片描述

缘由

第一种:

       当第一张上传完成时后面几张的status的值都为ready,是否在on-success中回传给file-list的值只取success状态下的呢?导致on-success只触发了一次,后面几张因为status问题而不往下执行了,于是决定使用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 })
	}
},

第二种:

getFile返回undefined,查看getFile方法,this.uploadFiles为空,未进入every循环,而this.uploadFiles的值来自fileList,而fileList由父组件传入。所以原因出在父组件fileList传值的问题上。

function getFile(rawFile) {
  var fileList = this.uploadFiles;
  var target = void 0;
  fileList.every(function (item) {
    // 优化,如上传过不在上传
    target = rawFile.uid === item.uid ? item : null;
    return !target;
  });
  return target;
}

在父组件中发现uploadChange属性的函数做了文件大小过滤,导致fileList数据错误。呵呵,前人留下的bug

_uploadChange (file, fileList) {
  fileList = fileList.filter(ele => {
    return ele.size < 1024 * 1024 * 100 && ele.size > 0
  })
},

解决方法

文件过滤放在beforeUpdate中,返回false过滤文件终止上传

_beforeUpload (file) {
  if (file.size > 1024 * 1024 * 100) {
    this.$message({
      message: "单个文件 " + file.name + " 不能大于100M",
      type: "warning"
    })
    return false
  } else if (file.size <= 0) {
    this.$message({
      message: "文件 " + file.name + " 不能为空",
      type: "warning"
    })
    return false
  }
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用Vue的el-upload组件进行批量上传图片,你可以按照以下示例代码进行操作: ```html <template> <el-upload class="upload-demo" action="/your-upload-url" :multiple="true" :on-success="handleSuccess" :before-upload="beforeUpload" :limit="3" :auto-upload="false" :file-list="fileList" > <el-button slot="trigger" size="small" type="primary">选取文件</el-button> <el-button style="margin-left: 10px;" size="small" type="success" @click="submitUpload">上传到服务器</el-button> <div slot="tip" class="el-upload__tip">只能上传jpg/png文件,且不超过3个文件</div> </el-upload> </template> <script> export default { data() { return { fileList: [] }; }, methods: { handleSuccess(response, file, fileList) { // 上传成功的回调函数 console.log(response); }, beforeUpload(file) { // 上传前的钩子函数 const isJPG = file.type === 'image/jpeg' || file.type === 'image/png'; const isLt2M = file.size / 1024 / 1024 < 2; if (!isJPG) { this.$message.error('上传图片只能是 JPG/PNG 格式!'); } if (!isLt2M) { this.$message.error('上传图片大小不能超过 2MB!'); } return isJPG && isLt2M; }, submitUpload() { // 手动触发上传 this.$refs.upload.submit(); } } }; </script> ``` 在上面的示例代码中,我们使用了`el-upload`组件来实现批量上传图片的功能。其中,`action`属性指定了上传图片的接口地址,`multiple`属性设置为`true`表示可以选择多个文件进行上传。`on-success`属性指定了上传成功后的回调函数,`before-upload`属性指定了上传前的钩子函数,可以在这里进行一些文件格式和大小的校验。`limit`属性设置了最多可以上传的文件数量,`auto-upload`属性设置为`false`表示不自动上传,需要手动触发上传。`file-list`属性用于绑定已选择的文件列表。 在`handleSuccess`方法中,你可以处理上传成功后的逻辑,比如展示上传成功的图片或者保存上传成功的文件路径等。 在`beforeUpload`方法中,你可以进行一些文件格式和大小的校验,并返回`true`或`false`来决定是否继续上传。 最后,在`submitUpload`方法中,我们通过`this.$refs.upload.submit()`手动触发上传操作。 希望以上代码能够帮助到你,如果还有其他问题,请随提问。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值