el-uploader 文件上传后,又被修改,无法提交到后端 ERR_UPLOAD_FILE_CHANGED

problem

文件上传后,又被修改,无法提交到后端
具体步骤:

  1. 文件上传
  2. 本地文件打开并修改保存
  3. 提交ajax

这个问题不仅仅局限于el-uploader,是一个普遍性的问题

导致的问题

  • 问题1:提交请求时,控制台报错 net::ERR_UPLOAD_FILE_CHANGED
  • 问题2:本地文件下载失败 提示网络出错

reason

第2步文件修改后,之前上传的文件已经不存在,导致提示错误

solution

解决办法:思路是缓存文件

具体:

  1. 文件上传后 通过file->base64出错;
  2. 提交时将 base64->转回file

结果:

  • 控制台不报错,也可以正常下载。
  • 但是文件是修改前的文件,不是最新文件
// 辅助方法1:file转为base64
const fileToBase64 = (file) => {
    return new Promise(resolve => {
        const reader = new FileReader();
        reader.readAsDataURL(file);
        reader.onload = e => {
            return resolve(e.target.result)
        };
    })
}

// 辅助方法2:base64转为file
const base64ToFile = (base64, filename) => {
    var arr = base64.split(',');
    var type = arr[0].match(/:(.*?);/)[1];
    var fileExt = type.split('/')[1];
    var bstr = atob(arr[1]);
    var n = bstr.length;
    var u8arr = new Uint8Array(n);
    while (n--) { u8arr[n] = bstr.charCodeAt(n); }
    return new File([u8arr], filename, { type: type })
}

// httpRequest是指file onchange 这一类的回调事件
 httpRequest(data) {
      this.dataForm.file = data.file
      // 步骤1. 文件变化时 将上传文件转为base64 缓存起来
      fileToBase64(data.file).then(result=>{
          this.base64 = result
      })
  },
   
// 点击提交按钮,发起ajax请求
onSubmit() {
    if (!this.dataForm.file) {
        alert('请先上传文件')
        return
    }
    // 步骤2. 提交请求前将缓存的base64文件转为file文件提交
    let cacheFile = base64ToFile(this.base64, this.dataForm.file.name);
    this.dataForm.file = cacheFile
    axios.post('/order/create', this.dataForm)
        .then(function (response) {
            console.log(response);
        })
        .catch(function (error) {
            console.log(error);
        });
}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Vue和ElementUI的Table中,可以使用自定义模板来实现行内的`el-upload`文件添加和多文件上传功能。 以下是一个示例代码: ```html <template> <el-table :data="tableData"> <el-table-column prop="name" label="Name"></el-table-column> <el-table-column label="Avatar"> <template v-slot:default="{row}"> <el-upload class="avatar-uploader" action="/upload" :file-list="row.avatarList" :on-success="handleSuccess" :before-upload="beforeUpload" :limit="5" :multiple="true" list-type="picture-card" > <i class="el-icon-plus avatar-uploader-icon"></i> </el-upload> </template> </el-table-column> </el-table> </template> <script> export default { data() { return { tableData: [ { name: 'John', avatarList: [] }, { name: 'Mary', avatarList: [] }, { name: 'Mike', avatarList: [] } ] }; }, methods: { beforeUpload(file) { // 文件上传前的处理逻辑 }, handleSuccess(response, file, fileList) { // 文件上传成功后的处理逻辑 } } }; </script> ``` 在上述示例中,我们为`el-table-column`设置了一个自定义模板,并使用`{row}`来接收每一行的数据。然后在该模板中使用`el-upload`来实现文件上传,在`el-upload`的属性中设置了多选(`:multiple="true"`)和多文件上传限制(`:limit="5"`),并使用`row.avatarList`来表示每一行已上传文件列表。 需要根据实际情况修改`el-upload`的属性和事件,例如`action`是上传地址,`before-upload`是上传前的处理逻辑,`handleSuccess`是上传成功后的处理逻辑等。 总之,使用Vue和ElementUI的Table和Upload组件来实现行内的文件添加和多文件上传功能是非常简单的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值