详解Vue3使用axios的配置教程


Posted in Vue.js onApril 29, 2022

axios中文网站:axios-http.com/zh/

一、安装axios

npm install axios --save

二、配置axios,添加拦截器

在src目录下新建一个request文件夹,在里面新建index.ts(或者.js)文件,编辑代码如下:

import axios from 'axios'
// 创建一个 axios 实例
const service = axios.create({
	baseURL: '/api', // 所有的请求地址前缀部分
	timeout: 60000, // 请求超时时间毫秒
	withCredentials: true, // 异步请求携带cookie
	headers: {
		// 设置后端需要的传参类型
		'Content-Type': 'application/json',
		'token': 'your token',
		'X-Requested-With': 'XMLHttpRequest',
	},
})

// 添加请求拦截器
service.interceptors.request.use(
	function (config) {
		// 在发送请求之前做些什么
		return config
	},
	function (error) {
		// 对请求错误做些什么
		console.log(error)
		return Promise.reject(error)
	}
)

// 添加响应拦截器
service.interceptors.response.use(
	function (response) {
		console.log(response)
		// 2xx 范围内的状态码都会触发该函数。
		// 对响应数据做点什么
		// dataAxios 是 axios 返回数据中的 data
		const dataAxios = response.data
		// 这个状态码是和后端约定的
		const code = dataAxios.reset
		return dataAxios
	},
	function (error) {
		// 超出 2xx 范围的状态码都会触发该函数。
		// 对响应错误做点什么
		console.log(error)
		return Promise.reject(error)
	}
)
export default service

三、使用axios发送请求

在src目录下新建一个apis文件夹,这里面放入今后所有的请求文件,例如新建一个请求用户信息的接口user.ts,代码如下:

// 导入axios实例
import httpRequest from '@/request/index'

// 定义接口的传参
interface UserInfoParam {
	userID: string,
	userName: string
}

// 获取用户信息
export function apiGetUserInfo(param: UserInfoParam) {
    return httpRequest({
		url: 'your api url',
		method: 'post',
		data: param,
	})
}

接着在具体业务页面里使用这个请求,例如:

<script setup lang="ts">
import { onMounted } from 'vue'
import { apiGetUserInfo } from '@/apis/user'
function getUserInfo() {
	const param = {
		userID: '10001',
		userName: 'Mike',
	}
	apiGetUserInfo(param).then((res) => {
		console.log(res)
	})
}
onMounted(() => {
	getUserInfo()
})
</script>

附:Vue3 中全局引入 axios

main.js中

import axios from 'axios'
const app = createApp(App) // 将默认改写为这样
app.provide('$axios', axios)

组件内使用axios(compositionAPI)

<script setup>
    import { inject } from 'vue'
    const $axios = inject('$axios')
    $axios.get('https://api.github.com/users').then((resp) => {    
      console.log(resp.data)
    }).catch((err) => {
      console.log(err)
    })
</script>

总结

到此这篇关于Vue3使用axios的配置的文章就介绍到这了!


Tags in this post...

Vue.js 相关文章推荐
在Vue中使用mockjs代码实例
Nov 25 Vue.js
Vue如何实现验证码输入交互
Dec 07 Vue.js
在vue中动态修改css其中一个属性值操作
Dec 07 Vue.js
Vue-router中hash模式与history模式的区别详解
Dec 15 Vue.js
vue element和nuxt的使用技巧分享
Jan 14 Vue.js
Vue 数据响应式相关总结
Jan 28 Vue.js
vue使用v-model进行跨组件绑定的基本实现方法
Apr 28 Vue.js
vue3中provide && inject的使用
Jul 01 Vue.js
idea编译器vue缩进报错问题场景分析
Jul 04 Vue.js
Vue3.0中Ref与Reactive的区别示例详析
Jul 07 Vue.js
vue3引入highlight.js进行代码高亮的方法实例
Apr 08 Vue.js
vue ant design 封装弹窗表单的使用
Jun 01 Vue.js
vue生命周期钩子函数以及触发时机
Apr 26 #Vue.js
vue里使用create, mounted调用方法
vue elementUI批量上传文件
Apr 26 #Vue.js
vue.js 使用原生js实现轮播图
Apr 26 #Vue.js
如何vue使用el-table遍历循环表头和表体数据
vue 把二维或多维数组转一维数组
Apr 24 #Vue.js
Vue OpenLayer 为地图绘制风场效果
Apr 24 #Vue.js
You might like
php 购物车实例(申精)
2009/05/11 PHP
PHP字符串处理的10个简单方法
2010/06/30 PHP
关于Sphinx创建全文检索的索引介绍
2013/06/25 PHP
ThinkPHP之getField详解
2014/06/20 PHP
php多重接口的实现方法
2015/06/20 PHP
PHP实现Huffman编码/解码的示例代码
2018/04/20 PHP
Prototype 学习 Prototype对象
2009/07/12 Javascript
让div层随鼠标移动的实现代码 ie ff
2009/12/18 Javascript
Js组件的一些写法
2010/09/10 Javascript
有关于eclipse配置spket需要注意的一些地方
2013/04/07 Javascript
textarea焦点的用法实现获取焦点清空失去焦点提示效果
2014/05/19 Javascript
jQuery中wrapAll()方法用法实例
2015/01/16 Javascript
jquery.cookie实现的客户端购物车操作实例
2015/12/24 Javascript
使用JavaScript脚本判断页面是否在微信中被打开
2016/03/06 Javascript
下雪了 javascript实现雪花飞舞
2020/08/02 Javascript
layui 给数据表格加序号的方法
2018/08/20 Javascript
微信小程序实现的日期午别医生排班表功能示例
2019/01/09 Javascript
vue实现登录页面的验证码以及验证过程解析(面向新手)
2019/08/02 Javascript
Vue 样式切换及三元判断样式关联操作
2020/08/09 Javascript
JavaScript数组常用的增删改查与其他属性详解
2020/10/13 Javascript
Vue中inheritAttrs的使用实例详解
2020/12/31 Vue.js
python操作sqlite的CRUD实例分析
2015/05/08 Python
python 实时遍历日志文件
2016/04/12 Python
简单了解什么是神经网络
2017/12/23 Python
Django中使用 Closure Table 储存无限分级数据
2019/06/06 Python
Python爬虫 批量爬取下载抖音视频代码实例
2019/08/16 Python
numpy 矩阵形状调整:拉伸、变成一位数组的实例
2020/06/18 Python
Scrapy项目实战之爬取某社区用户详情
2020/09/17 Python
利用python进行文件操作
2020/12/04 Python
英国最大的电脑零售连锁店集团:PC World
2016/10/10 全球购物
英国奢侈品概念店:Base Blu
2019/05/16 全球购物
物业管理应届生求职信
2013/10/28 职场文书
2014年财务个人工作总结
2014/12/08 职场文书
员工工作表现自我评价
2015/03/06 职场文书
TV动画《神废柴☆偶像》公布先导PV
2022/03/20 日漫
python blinker 信号库
2022/05/04 Python