Vue 设置axios请求格式为form-data的操作步骤


Posted in Javascript onOctober 29, 2019

Cover

Vue 设置axios请求格式为form-data的操作步骤

在Vue中使用axios

这个老生常谈了,还是先记录一遍,方面后面自己查。

!!! 设置form-data请求格式直接翻到后面看。

1. 安装axios

在项目下执行npm install axios。

之后在main.js中,添加:

import axios from 'axios' //引入

//Vue.use(axios) axios不能用use 只能修改原型链 
Vue.prototype.$axios = axios

2. 发送GET请求

axios封装了get方法,传入请求地址和请求参数,就可以了,同样支持Promise。

//不带参数的get请求

let url = "..."
this.$axios.get(url)
.then((res) => {
 console.log(res) //返回的数据
})
.catch((err) => {
 console.log(err) //错误信息
})

不过它的参数需要写在params属性下,也就是:

//带参数的get请求

let url = "...getById"
this.$axios.get(url, {
 params: {
  id: 1
 }
})
.then((res) => {
 console.log(res) //返回的数据
})
.catch((err) => {
 console.log(err) //错误信息
})

2. 发送post请求

与上面相同,就是参数不需要写在params属性下了,即:

//带参数的post请求

let url = "...getById"
let data = {
 id: 1
}

this.$axios.post(url, data)
.then((res) => {
 console.log(res) //返回的数据
})
.catch((err) => {
 console.log(err) //错误信息
})

3. 经典写法

axios也可以用jQ的写法,不过回调函数还是Promise的写法,如:

this.$axios({
 method: 'post',
 url: '...',
 data: {
 firstName: 'Fred',
 lastName: 'Flintstone'
 }
}).then((res) => {
 console.log(res)
})

设置form-data请求格式

我用默认的post方法发送数据的时候发现后端获取不到数据,然而在network中看到参数是的确传出去的了。而且用postman测试的时候也是可以的,比较了下两个的不同发现是postman使用的是form-data格式,于是用form-data格式再次请求,发现OJBK

在查找设置请求格式的时候花了点时间,网上的方案有好几个,这个我亲测成功,发上来。

import axios from "axios" //引入

//设置axios为form-data
axios.defaults.headers.post['Content-Type'] = 'application/x-www-form-urlencoded';
axios.defaults.headers.get['Content-Type'] = 'application/x-www-form-urlencoded';
axios.defaults.transformRequest = [function (data) {
 let ret = ''
 for (let it in data) {
  ret += encodeURIComponent(it) + '=' + encodeURIComponent(data[it]) + '&'
 }
 return ret
}]


//然后再修改原型链
Vue.prototype.$axios = axios

以上这篇Vue 设置axios请求格式为form-data的操作步骤就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
动态加载js文件 document.createElement
Oct 14 Javascript
用CSS+JS实现的进度条效果效果
Jun 05 Javascript
jQuery基本过滤选择器使用介绍
Apr 18 Javascript
JS动态创建Table,Tr,Td并赋值的具体实现
Jul 05 Javascript
在子窗口中关闭父窗口的一句代码
Oct 21 Javascript
常见浏览器多长时间会提示“脚本运行时间过长”总结
Apr 29 Javascript
javascript实现超炫的向上滑行菜单实例
Aug 03 Javascript
Node.js+Express配置入门教程详解
May 19 Javascript
Ajax实现不刷新取最新商品
Mar 01 Javascript
Angular中sweetalert弹框的基本使用教程
Jul 22 Javascript
利用原生JavaScript实现造日历轮子实例代码
May 08 Javascript
如何在Angular8.0下使用ngx-translate进行国际化配置
Jul 24 Javascript
js单线程的本质 Event Loop解析
Oct 29 #Javascript
解决axios post 后端无法接收数据的问题
Oct 29 #Javascript
使用axios请求接口,几种content-type的区别详解
Oct 29 #Javascript
vue+elementui 对话框取消 表单验证重置示例
Oct 29 #Javascript
vue实现路由监听和参数监听
Oct 29 #Javascript
基于axios 的responseType类型的设置方法
Oct 29 #Javascript
关于vue2强制刷新,解决页面不会重新渲染的问题
Oct 29 #Javascript
You might like
使用PHP实现Mysql读写分离
2013/06/28 PHP
PHP中变量引用与变量销毁机制分析
2014/11/15 PHP
php curl优化下载微信头像的方法总结
2018/09/07 PHP
CI框架实现创建自定义类库的方法
2018/12/25 PHP
redis+php实现微博(一)注册与登录功能详解
2019/09/23 PHP
JavaScript-RegExp对象只能使用一次问题解决方法
2014/06/23 Javascript
JavaScript错误处理
2015/02/03 Javascript
javascript replace()第二个参数为函数时的参数用法
2016/12/26 Javascript
ES6中的箭头函数实例详解
2017/04/06 Javascript
Node.js创建Web、TCP服务器
2017/12/05 Javascript
微信小程序事件 bindtap bindinput代码实例
2019/08/26 Javascript
[02:40]DOTA2英雄基础教程 巨牙海民
2013/12/23 DOTA
[47:22]Mineski vs Winstrike 2018国际邀请赛小组赛BO2 第二场 8.16
2018/08/17 DOTA
python通过线程实现定时器timer的方法
2015/03/16 Python
Python数据可视化编程通过Matplotlib创建散点图代码示例
2017/12/09 Python
Python排序搜索基本算法之希尔排序实例分析
2017/12/09 Python
详解Python中where()函数的用法
2018/03/27 Python
numpy.transpose对三维数组的转置方法
2018/04/17 Python
Django 表单模型选择框如何使用分组
2019/05/16 Python
如何使用selenium和requests组合实现登录页面
2020/02/03 Python
Pycharm IDE的安装和使用教程详解
2020/04/30 Python
HTML5实现视频弹幕功能
2019/08/09 HTML / CSS
英国羊皮鞋类领先品牌:Just Sheepskin
2019/12/12 全球购物
科颜氏香港官方网店:Kiehl’s香港
2021/03/07 全球购物
天游软件面试
2013/11/23 面试题
给定一个时间点,希望得到其他时间点
2013/11/07 面试题
广告学专业应届生求职信
2013/10/01 职场文书
统计学专业毕业生的自我评价分享
2013/11/28 职场文书
银行办公室岗位职责
2014/03/10 职场文书
英语教师岗位职责
2014/03/16 职场文书
《庐山的云雾》教学反思
2014/04/22 职场文书
实习公司领导推荐函
2014/05/21 职场文书
小学社团活动总结
2014/06/27 职场文书
学生检讨书范文
2014/10/30 职场文书
实习工作表现评语
2014/12/31 职场文书
SQL Server数据库备份和恢复数据库的全过程
2022/06/14 SQL Server