el-upload批量添加文件转换为base64格式上传,以及on-change钩子存在的坑和解决方法

在Vue.js项目中,使用el-upload组件批量添加文件时,on-change事件可能导致文件重复添加到imgList。原因是on-change在每个文件状态变化时执行,异步的base64转换在多次调用中累积了多个reader.onload事件。为解决此问题,应将base64转换移到表单提交时执行,并利用Promise.all确保所有文件转换完成后再发送请求。
摘要由CSDN通过智能技术生成
<template>
    <el-upload 
        class="upload-demo" 
        action=" " //必选参数,上传的地址
        :multiple="true" //是否支持多选文件
        :limit="5"  //最大允许上传个数
        accept="image/png, image/jpeg" //接受上传的文件类型
        :on-change="(file,fileList) => {uploadChange(file,fileList,'reexaminationForm')}" //文件状态改变时的钩子 
        :on-remove="(file,fileList) => {handleRemove(file,fileList,'reexaminationForm')}"
//文件列表移除文件时的钩子
        :before-remove="beforeRemove" //删除文件之前的钩子
        :on-exceed="handleExceed" //文件超出个数限制时的钩子
        :auto-upload="false" //是否在选取文件后立即进行上传
        :file-list="reexaminationForm.fileList"> //上传的文件列表
        <el-button size="mini" type="primary">点击上传</el-button>
    </el-upload>
</template>
<script>
const vm = new Vue({
    el: "#app",
    data() {
        return {
            //表单存在多个,这里仅列出一个
            reexaminationForm: {
                fileList: []
            },
            imgList: []
        }
    },
    methods: {
        uploadChange(file, fileList, formName) {
            vm[formName].fileList.push(file); //保存文件到相应表单下的fileList
            vm.transformBase64(vm[formNa
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值