上传文件修改参数的type

在上传文件时,如果需要携带表单数据且将content-type设置为application/json,可以使用FormData对象。将文件和其他表单数据通过append方法添加到FormData中,并可以指定某个参数的content-type。对于antd的Upload组件,在Form中使用时,不能直接通过getFieldsValue获取File数据,应利用beforeUpload处理并保存。
摘要由CSDN通过智能技术生成

上传文件同时修改表单参数的content-type

背景

我们上传文件的时候需要对文件进行处理,如果要带有表单信息并且要求表单信息的content-type为application/json该如何处理呢?

编码实战

let formData = new FormData(); // 创建form对象
formData.append('file', file); // 通过append向form对象添加文件数据
formData.append('a', 'a'); // 添加form表单中其他数据
formData.append('b', 'b'); // 添加form表单中其他数据
formData.append("videoeditform",JSON.stringify(this.videoeditform));//  添加form表单中其他数据
formData.append('c',new Blob([JSON.stringify(c)], {
          type: 'application/json',
        }),
      );// 修改某一个参数的content-type

额外补充

antd组件Upload上传问题

使用antd的Form控制Upload组件的时候,不能直接使用form.getFieldsValue获取Upload的信息,因为这样获取到的不是File类型的数据,而是一个数组类型,这样子的话上传会发现上传的文件不是二进制。

正常格式如下
在这里插入图片描述

非正常格式如下
在这里插入图片描述

处理方案

使用Upload组件的beforeUpload属性,并使用useState保存,上传的时候在进行处理即可

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值