使用axios请求时,发送formData请求

最近做的一个项目中有一个特例接口,传json后端接收不到,对接的后端又不愿意改接口,只能用formData方式传参,由于好多年没有用过formData,头痛了一会,找到了解决方法,发现非常简单,在此做个笔记!

var formData = new FormData();
formData.append("username", "Groucho");
formData.append("accountnum", 123456); 
fetch('/users', {
  method: 'POST',
  body: formData
})

  

对象转FormData对象

对于FormDat对象,像上面那种形式可以直接添加参数比较方便,但是对于对象或者嵌套对象:

 let userObj = {userName: ’xxx', age: '21'}
 formData.append('user', userObj)

如果已经有了一个对象,里边字段非常多的话,可以这样:

let param {{name:"张三"},{aa:"222"}}
let formData = new FormData();
Object.keys(param).forEach(key => {
  formData.append(key, param[key]);
});

该问题方案解决方法来自于https://www.cnblogs.com/wonyun/p/7966967.html

 

原文地址:https://www.cnblogs.com/yixiancheng/p/11188631.html