方法一:通过配置file-list(推荐使用)

html部分:

<el-upload
    class="upload-demo list-uploadbtn"
    ref="upload"
    :action="curBastUrl"
    :auto-upload="false"
    :on-remove="updataRemove"
    :before-upload="beforeUpload"
    :on-change="updatachange"
    :file-list="fileList"
    :multiple="true">
    <el-button size="small">点击上传</el-button>
</el-upload>
<el-button type="primary" @click="submitUpload">确 定</el-button>

js部分:

submitUpload() {  // 导入
    let formData = new FormData();  //  用FormData存放上传文件
    this.fileList.forEach(file => { 
        formData.append('file', file.raw)		
    }) 
          
    formData.append('categoryDirectory', this.filedata.categoryDirectory)
 
    // importCase是上传接口
    importCase(formData).then((res) => { 
        //手动上传无法触发成功或失败的钩子函数,因此这里手动调用 
      this.updataSuccess(res.data) 
    }, (err) => {
       
    })
}

关键代码说明:

  • auto-upload 设置为 false 用于关闭组件的自动上传;
  • file-list 配置一个数组用于接收上传的文件列表;
  • multiple 设置为 true 表示支持多选文件;
  • action 配置为完整的上传接口url,不配置会报错
  • 不用配置 dataon-successon-error等参数,因为手动上传不会用到这些配置信息;
  • 最后通过点击按钮手动调用上传函数 submitUpload ,创建一个 FormData 把 fileList  的文件存进去。

方法二:通过配置http-request

html部分:

<el-upload
    class="upload-demo list-uploadbtn"
    ref="upload"
    :action="curBastUrl"
    :auto-upload="false"
    :http-request="uploadFile"
    :on-remove="updataRemove"
    :before-upload="beforeUpload"
    :on-change="updatachange"
    :multiple="true">
    <el-button size="small">点击上传</el-button>
</el-upload>
<el-button type="primary" @click="submitUpload">确 定</el-button>

js部分:

submitUpload() {  // 导入
    let tempData =  this.filedata
    this.filedata = new FormData()  //  用FormData存放上传文件
    this.$refs.upload.submit()  // 会循环调用uploadFile方法,多个文件调用多次
 
    this.filedata.append('categoryDirectory', tempData.categoryDirectory)
 
    // importCase是上传接口
    importCase(this.filedata).then((res) => { 
    //手动上传无法触发成功或失败的钩子函数,因此这里手动调用 
      this.updataSuccess(res.data) 
    }, (err) => {
       
    })
}
uploadFile(file) {
    this.filedata.append('file', file.file)
}

关键代码说明:

  • http-request 自定义上传方法;
  • 最后通过点击按钮手动调用上传函数 submitUpload ,创建一个 FormData, 调用 upload 组件的 submit 方法的时候会循环调用 http-request 配置的方法,从而往 FormData  里存放文件。