使用vue插件axios传数据的Content-Type及格式问题详解
1.一般来说,前后台对接,常用的Content-Type有:
application/json,application/x-www-form-urlencoded 以及 multipart/form-data,当我们使用axios时,一般不需要我们主动去设置Content-Type,而是跟着我们传的数据格式自动适应。
2.get请求
get请求时传递的参数是会出现在url里面的,我们使用aixos传递get请求时可用格式如下
(1)将参数拼接在url里
this.$axios({ method: 'get', url: this.$store.state.api1 + '&username=' + 'xxx' + '&password=' + 'xxx' })
(2)将参数放入params对象里
this.$axios({ method: 'get', url: this.$store.state.api1, params: { username: 'xxx', password: 'xxx' } })
3.post请求
(1)当我们要传对象时,此时的 Content-Type 为 application/json 类型,传递的格式如下,将传递的参数放入对象中:
this.$axios({ url: this.$store.state.api1, method: 'post', data: { username: 'xxx', password: 'xxx' } })
(2)当我们要传字符串时,Content-Type 为 application/x-www-form-urlencoded 类型,传递的格式有如下:
this.$axios({ method: 'post', url: this.$store.state.api1, data: 'username=' + 'xxx' + '&password=' + 'xxx' })
this.$axios({ method: 'post', url: this.$store.state.api1, data: qs.stringify({ username: 'xxx', password: 'xxx' })
(3)当我们要传文件时,Content-Type 需要使用 multipart/form-data,格式如下:
// 获取文件 let input = document.querySelector('.input_file') let curFiles = input.files // 将文件放入formData中 let formData = new FormData() for(let file of curFiles){ formData.append('files', file) } // 将需要传递的参数放入formData中 formData.append('username', 'xxx') formData.append('password', 'xxx') // 调接口 this.$axios({ url: this.$store.state.api1, method: 'post', data: formData })
到此这篇关于使用vue插件axios传数据的Content-Type以及格式问题的文章就介绍到这了,更多相关vue Content-Type内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
关于vue3.0中的this.$router.replace({ path: ''/''})刷新无效果问题
这篇文章主要介绍了关于vue3.0中的this.$router.replace({ path: '/'})刷新无效果问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-01-01Vue-cli 使用json server在本地模拟请求数据的示例代码
本篇文章主要介绍了Vue-cli 使用json server在本地模拟请求数据的示例代码,非常具有实用价值,需要的朋友可以参考下2017-11-11
最新评论