Bulandent / blog

高级前端进阶博客,记录个人前端成长之路。包括但不限制于:es6、node、vue、小程序、浏览器、网络、设计模式、算法和数据结构、web安全、性能优化、工程化等。
80 stars 8 forks source link

如何做到发送一次请求上传多个文件(使用 el-upload) #21

Open Bulandent opened 3 years ago

Bulandent commented 3 years ago

最近在做项目的时候有一个需求,需要导入word文档,并且需要支持多选。element-uiupload 组件支持多选文件,只需要配置参数 multipletrue 即可。但是这个组件默认会将多选的文件分多次进行上传,于是就会存在多次的上传请求,由于后台的接口要求是一次请求能够上传多个文件,且我们也知道请求多了会对服务器造成更大的压力,因而基于多种原因,这个 upload 的上传行为得进行改造一番。

先来看下改造前后的结果

改造前的结果:同时上传2个文件,会发出2次对接口的请求,每次请求里包含了一个文件。

upload_result_after

改造后的结果:同时上传2个文件,会发出一次接口请求,接口入参里包含2个文件。

upload_result_after

方法一:通过配置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) => {
       
    })
}

关键代码说明:

方法二:通过配置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)
}

关键代码说明: