文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

element自定义多文件上传触发多次on-change问题怎么解决

2023-07-05 17:42

关注

这篇文章主要介绍“element自定义多文件上传触发多次on-change问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“element自定义多文件上传触发多次on-change问题怎么解决”文章能帮助大家解决问题。

element自定义 多文件上传 触发多次on-change

由于项目需要,图片上传需要进行压缩之后在调用接口,那就只能走自定义上传

自定义上传关键在于:

<el-upload    ref="upload"    action="#"  // 上传入口改成 #    :multiple="true" // 多文件上传开启    :on-change="handleChange" // 改变监听    :file-list="fileList"  //文件列表    :auto-upload="false" // 自动上传关闭>    <i class="el-icon-plus"></i></el-upload>

由于 auto-upload 设置为 false 之后,before-upload 会失效,所以上传的事件之前体现在 change 里。

但是这样呢在上传文件时无论是多图还是单图,在上传后都会走2次 handleChange ,

此时我们需要一个防抖方法,来限制它。

handleChange(file, fileList) {    //  防抖  let length = fileList.length  this.maxLength = Math.max(length, this.maxLength)  setTimeout(() => {    if (length === this.maxLength) {      // 你的上传文件逻辑    }  }, 100)}

this.maxLength 默认设置 0 就行,要记得在上传成功(完成)后需要设置为默认 0。

下面附上我完整的代码

change 事件

handleChange(file, fileList) {    //  防抖  let length = fileList.length  this.maxLength = Math.max(length, this.maxLength)  setTimeout(() => {    if (length === this.maxLength) {        // 图片验证      this.uploadFilesVerification(fileList)    }  }, 100)}

图片验证: uploadFilesVerification

// 图片验证async uploadFilesVerification(fileList) {  let resFileList = []  for (const key in fileList) {    console.log('fileList[key] :>> ', fileList[key])    // 判断文件大小(5M)    if (fileList[key].size > 1024 * 1024 * 5) {      this.$message.warning('图片大小不可以超过5M')      return    }    // 图片压缩(这里用的 lrz,项目不需要可以忽略)    const lrzData = await lrz(fileList[key].raw, { quality: 0.5 })    // 内容验证    //  xxxx     resFileList.push(lrzData.origin)  }   // 上传图片  this.customUploadFn(resFileList) }

自定义上传:customUploadFn

// 自定义上传async function customUploadFn(fileList) {  let form = new FormData()  fileList.forEach((item) => {    form.append('files', item)  })  const { data } = await uploadFiles(form) // 上传 api 接口  console.log('data :>> ', data)  data.forEach((item) => {    this.goodsImgList.push(item) // 图片回显数组  })  this.fileList = [] // 清空图片已经上传的图片列表(绑定在上传组件的file-list)  this.maxLength = 0 // 恢复默认值}

el-upload自定义上传触发多次change事件解决

昨天在做项目时,有个附件上传的需求,需要使用formdata上传文件,并且支持多文件上传,使用el-upload on-change时发现会调用多次,以下是我整理出来规避的方法。

vue部分:

<el-upload :on-change="handleUpload" :on-remove="handleRemove" :auto-upload="false" :show-file-list="false" drag action="#" ref="upload" multiple  >  <div class="el-upload__text">拖拽文件或点击上传</div></el-upload>

ts/js部分:

  // 附件上传  private handleUpload(file, fileList) {    let length = fileList.length;    this.maxFileLength = Math.max(length, this.maxFileLength)    setTimeout(() => {      if (this.maxFileLength !== length) {        return      }      fileList.forEach(item => {        this.fileList.push(item.raw)      })    }, 0)  }

定义一个全局变量maxFileLength 用于计算当前上传次数,如果上传次数等于上传文件的数量长度则将文件放到当前下发文件的参数中。

关于“element自定义多文件上传触发多次on-change问题怎么解决”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯