关于vue中axios发请求的小疑问
主要是关于get和post还有ajax的一些小问题:
1:为何发请求的时候,get请求发送params参数不需要序列化(就像图2中的get请求里边发送参数一样),而post里边发送请求体body就需要序列化一下呢(就像图1中需要querystring.stringify对参数做处理)?
2:图1中序列化参数的时候为啥需要 || paramObj 呢?难道有些情况下序列化会失效吗?
3:axios的get请求好像一般传参都用params,可以不用params而像post一样发送请求体吗?
4:axios官方文档中,这种写法看的不是很懂,中括号加逗号是一种什么写法呢
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
1.
get
请求params
不需要序列化, 是因为框架(axios
)帮你做了这件事.打开
network
, 你的url
问号后面的, 就是你get
携带的请求参数.post
请求, 其实如果你不用queryString.stringify
也没关系. 只不过是后端能否正确解析这个格式而已.你可以试一下, 比如
queryString.stringify
的格式, 它的Content-type
是application/x-www-form-urlencoded
而如果是直接传入一个对象, 他的
Content-type
是application/json;charset=UTF-8
2.说实话我也没看明白....可以确认一下, 当
paramObj
为空的时候, 这个queryString.stringify
返回值是什么.3.可以.但是一般没人会这么写.
http
请求中, 无论是get
,post
, 本质都是一样的, 但是和第一个问题一样, 是后端能否正确解析的问题. 一般后端不会去解析get
请求的body.4.
[]
代表可选参数, 比如 :1、get、post 是 RESTful 风格的,这个只是一种约定,你可以请求 get 时用 body 传值;
2、axios 里面自己做处理的,params 会默认是通过 url传参,所以不需要格式化,data 是放在 body 里面的;
get请求的参数是在url中,并且只有一种格式
a=1&b=2
。 但是post请求的参数有多种格式,具体由contentType
指定,一般情况有多种情况, 所以需要用户自己进行序列化。其他有一些比较人性化的库会根据不同的参数, 自动选择对应的序列化方式。application/json
: {"a":1,"b":1}application/x-www-form-urlencoded
:a=1&b=2