前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >element-ui上传组件,通过自定义请求上传文件

element-ui上传组件,通过自定义请求上传文件

作者头像
codeniu
发布2022-02-25 13:48:41
3.7K0
发布2022-02-25 13:48:41
举报
文章被收录于专栏:codeniucodeniu

记录使用element-ui上传组件,通过自定义请求上传文件需要注意的地方。

代码语言:javascript
复制
<el-upload
           ref="uploadMutiple"
           :auto-upload="false"
           action="Fake Action"
           :on-success="allHandleSuccess"
           :on-change="handleChange"
           :file-list="fileList"
           :http-request="allUpload"
           :before-upload="before_upload"
           multiple
>选取文件</el-upload>

<el-button type="primary" size="small" @click="submitUpload">上传</el-button>

首先关闭自动上传,并给随便给action赋值一个字符串。(action是必填属性)

代码语言:javascript
复制
       :auto-upload="false"
       action="Fake Action"

通过:on-change钩子函数,拿到文件列表:

代码语言:javascript
复制
    handleChange(file, fileList) {
      this.fileList = fileList;
    },

一般情况下,我们在submitUpload()的点击事件中去触发上传:

代码语言:javascript
复制
submitUpload() {
	this.$refs.uploadMutiple.submit();
}

之后组件会触发:http-request钩子行数。需要注意的是,这里你的fileList中有几个文件,就会执行几次:http-request钩子函数。这意味着,如果你把上传请求写在:http-request钩子函数中,就会造成重复不必要的请求。直接在submitUpload()中写post请求即可。只需要把文件封装为formData对象,作为参数传给后台即可。

代码语言:javascript
复制
      let formData = new FormData();
      this.fileList.forEach(item => {
        formData.append("files", item.raw);
      });

	  this.axios.post(api, formData);

下面是后台接口的写法:

代码语言:javascript
复制
public JSONResponse archiveBatchImport(@RequestParam("files") MultipartFile[] files){}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-03-20 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 记录使用element-ui上传组件,通过自定义请求上传文件需要注意的地方。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档