vue3如何使用el-upload上传文件(el-upload,vue3,开发技术)

时间:2024-05-05 13:23:35 作者 : 石家庄SEO 分类 : 开发技术
  • TAG :

    vue3%E5%A6%82%E4%BD%95%E4%BD%BF%E7%94%A8el-upload%E4%B8%8A%E4%BC%A0%E6%96%87%E4%BB%B6

在项目开发的过程中上传文件的需求是经常会遇到的,这篇文章我们就详细介绍使用elementplus中el-upload来上传文件了。

我们先来看一下el-upload可以配置哪些属性和事件。

action: 请求url

headers: 设置上传的请求头部

method: 设置上传请求方法

multiple: 是否支持多选文件

data: 上传时附带的额外参数

name: 上传的文件字段名

with-credentials: 支持发送cookie凭证信息

以上这些参数都是采用action的默认方式请求时使用的,如果我们使用自定义的请求方法,这些属性基本上都不会使用到。

show-file-list: 是否显示已上传文件列表

drag: 是否启用拖拽上传

accept: 接受上传的文件类型

on-preview: 点击文件列表中已上传文件时的钩子

on-remove: 文件列表移除文件时的钩子

on-success: 文件上传成功时的钩子

on-error: 文件上传失败时的钩子

on-progress: 文件上传时的钩子

on-change: 文件状态改变时的钩子,添加,上传成功和失败都会被调用

on-exceed: 当超出限制时执行的钩子

before-upload: 文件上传之前的钩子,参数为上传的文件, 若返回false或者返回 Promise 且被 reject,则停止上传。

before-remove: 删除文件之前的钩子,参数为上传的文件和文件列表, 若返回 false 或者返回 Promise 且被 reject,则停止删除。

file-list/v-model:file-list: 默认上传文件

list-type: 文件列表的类型,'text' | 'picture' | 'picture-card'。

auto-upload: 是否自动上传文件

http-request: 覆盖默认的 Xhr 行为,允许自行实现上传文件的请求

disabled: 是否禁用上传

limit: 允许上传文件的最大数量

abort: 取消上传请求

submit: 手动上传文件列表

clearFiles: 清空已上传的文件列表(该方法不支持在 before-upload 中调用)

handleStart: 手动选择文件

handleRemove: 手动移除文件。 filerawFile 已被合并。

上传图片的时候我们一般都会重写http请求,不使用默认的action去请求,因此action我们一般都会设置成‘#’。

一般上传文件的话请求头中的Content-Type: multipart/form-data;我们的需求中还需要设置文件的随机数,因此请求头需要是这样的Content-Type: multipart/form-data; boundary=----WebKitFormBoundarypzSlbADtTRuFx5FC。

下面是我遇到的问题。

设置了Content-Type: multipart/form-data;此时请求一直没有随机数boundary=----WebKitFormBoundarypzSlbADtTRuFx5FC。

如果设置了全局的content-type,会发现上传接口设置multipart/form-data是不起作用的,因为没有Boundary,所以上传必定失败,服务器500。

然后尝试手动添加Boundary,这次错误变400了

后来通过查询资料,说不用设置Content-Type: multipart/form-data;只要参数是formData形式,浏览器就会自动将请求头的Content-Type转成Content-Type: multipart/form-data; boundary=----WebKitFormBoundarypzSlbADtTRuFx5FC。

但是我不设置的话就是默认的application/json。

于是查阅资料发现axios的transformRequest属性可以在向服务器发送请求数据之前修改请求数据,因为我们的请求在默认的post请求方式时Content-Type的值是application/json,需要去掉默认的值,这样浏览器就可以自动添加了。

如果还要传其他的参数,其他的参数必须也要append进去,否则可能会报参数错误。

本文:vue3如何使用el-upload上传文件的详细内容,希望对您有所帮助,信息来源于网络。
上一篇:Pytorch:Conv2d卷积前后尺寸怎么设置下一篇:

15 人围观 / 0 条评论 ↓快速评论↓

(必须)

(必须,保密)

阿狸1 阿狸2 阿狸3 阿狸4 阿狸5 阿狸6 阿狸7 阿狸8 阿狸9 阿狸10 阿狸11 阿狸12 阿狸13 阿狸14 阿狸15 阿狸16 阿狸17 阿狸18