预备知识:
post提交数据的四种编码方式
1.application/x-www-form-urlencoded
传表单格式
键值对。
2.multipart/form-data
能传文件,不仅仅是表单数据
这也是一种比较常见的post数据格式,我们用表单上传文件时,必须使form表单的enctype属性或者ajax的contentType参数等于multipart/form-data。使用这种编码格式时发送到后台的数据长得像这样子

我把值json.Stringify(val)了。
演示下,如果需要用post发送formdata格式的数据该如何配置。背景是因为我们要上传一个超长的数组。
在封装好axios请求也就是写好了请求拦截器后,在api文件中这样封装

使用时这样
let param = new FormData(); //创建form对象
param.append('chatRecord',JSON.stringify(this.msgList));//你要传的键名,值 因为我要传一个数组 所以先转换成json字符串
commitChat(this.consultId,param).then(res=>{
console.log(res.data)
})
如果没有封装,直接写,可以参考下面的写法:
日后有空补充,反正和封装的差不多
3.application / json
如果使用這種編碼方式,那麼傳遞到後台的將是序列化後的json 字符串。我們可以將application / json與application / x-www-form-urlencoded發送的數據進行比較
4.text/xml
传纯粹的文本,就是字符串。
剩下的一种编码格式是text/xml,这种格式我没有怎么使用过
本文介绍了使用axios通过FormData进行POST请求的方法,特别是在处理需要上传文件或长数组的情况下。重点讲解了application/x-www-form-urlencoded、multipart/form-data、application/json以及text/xml四种编码方式,其中multipart/form-data用于文件上传,而application/json则用于发送序列化的JSON字符串。

被折叠的 条评论
为什么被折叠?



