搜索

查看: 3073|回复: 11

[JavaScript] vue3使用el-upload上传文件示例详解

[复制链接]
发表于 2023-5-4 11:50:47 | 显示全部楼层 |阅读模式
Editor 2023-5-4 11:50:47 3073 11 看全部
目录
  • el-upload上传文件
  • 属性
  • 方法
  • 上传图片的实现
  • 存在的坑
  • 问题1
  • 问题2
  • 问题3
    el-upload上传文件
    在项目开发的过程中上传文件的需求是经常会遇到的,这篇文章我们就详细介绍使用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: 手动移除文件。 file 和rawFile 已被合并。
    上传图片的实现
    上传图片的时候我们一般都会重写http请求,不使用默认的action去请求,因此action我们一般都会设置成‘#’。

      
       
       
       
          
            

            
             
                
             
             
                
             
            
          
       
       
       
          

       
      


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

    问题1
    设置了Content-Type: multipart/form-data;此时请求一直没有随机数boundary=----WebKitFormBoundarypzSlbADtTRuFx5FC。
    如果设置了全局的content-type,会发现上传接口设置multipart/form-data是不起作用的,因为没有Boundary,所以上传必定失败,服务器500。
    然后尝试手动添加Boundary,这次错误变400了

    问题2
    后来通过查询资料,说不用设置Content-Type: multipart/form-data;只要参数是formData形式,浏览器就会自动将请求头的Content-Type转成Content-Type: multipart/form-data; boundary=----WebKitFormBoundarypzSlbADtTRuFx5FC。
    但是我不设置的话就是默认的application/json。
    于是查阅资料发现axios的transformRequest属性可以在向服务器发送请求数据之前修改请求数据,因为我们的请求在默认的post请求方式时Content-Type的值是application/json,需要去掉默认的值,这样浏览器就可以自动添加了。
      globObj.$axios({
        url: url,
        method: 'post',
        transformRequest: [function(data, headers) {
          // 去除post请求默认的Content-Type
          delete headers['Content-Type']
          return data
        }],
        data: formData,
        timeout: 300000
      }).then(res => {
        ElMessage.success('资产添加成功');
      }).catch((err) => {
        console.log(err);
      });

    问题3
    如果还要传其他的参数,其他的参数必须也要append进去,否则可能会报参数错误。
    const formData = new FormData();
    formData.append('file', file);
    // 其他参数
    formData.append('mailSys', mailSys);
    以上就是vue3使用el-upload上传文件示例详解的详细内容,更多关于vue3 el-upload上传文件的资料请关注知鸟论坛其它相关文章!
  • 回复

    使用道具 举报

    发表于 2023-6-28 17:50:44 | 显示全部楼层
    幸福341 2023-6-28 17:50:44 看全部
    其实我一直觉得楼主的品味不错!呵呵!知鸟论坛太棒了!
    回复

    使用道具 举报

    发表于 2023-6-29 14:55:14 | 显示全部楼层
    戏做顿 2023-6-29 14:55:14 看全部
    楼主,大恩不言谢了!知鸟论坛是最棒的!
    回复

    使用道具 举报

    发表于 2023-6-29 17:42:40 | 显示全部楼层
    哈哈SE7 2023-6-29 17:42:40 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    回复

    使用道具 举报

    发表于 2023-6-30 01:38:17 | 显示全部楼层
    惜颜705 2023-6-30 01:38:17 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    发表于 2023-6-30 08:31:21 | 显示全部楼层
    123456865 2023-6-30 08:31:21 看全部
    楼主发贴辛苦了,谢谢楼主分享!我觉得知鸟论坛是注册对了!
    回复

    使用道具 举报

    发表于 2023-6-30 10:15:09 | 显示全部楼层
    123456809 2023-6-30 10:15:09 看全部
    既然你诚信诚意的推荐了,那我就勉为其难的看看吧!知鸟论坛不走平凡路。
    回复

    使用道具 举报

    发表于 2023-6-30 23:09:10 | 显示全部楼层
    小妖花满楼满fx 2023-6-30 23:09:10 看全部
    这个帖子不回对不起自己!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    发表于 2023-7-3 22:20:33 | 显示全部楼层
    123456825 2023-7-3 22:20:33 看全部
    论坛不能没有像楼主这样的人才啊!我会一直支持知鸟论坛
    回复

    使用道具 举报

    发表于 2023-7-4 00:11:29 | 显示全部楼层
    dxf17 2023-7-4 00:11:29 看全部
    楼主,我太崇拜你了!我想我是一天也不能离开知鸟论坛
    回复

    使用道具 举报

    • 您可能感兴趣
    点击右侧快捷回复 【请勿灌水】
    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则 返回列表

    RSS订阅| SiteMap| 小黑屋| 知鸟论坛
    联系邮箱E-mail:zniao@foxmail.com
    快速回复 返回顶部 返回列表