详解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+Element实现增删改查的示例源码
Nov 23 Vue.js
vue使用exif获取图片旋转,压缩的示例代码
Dec 11 Vue.js
Vue 组件注册全解析
Dec 17 Vue.js
vue项目中openlayers绘制行政区划
Dec 24 Vue.js
基于Vue2实现移动端图片上传、压缩、拖拽排序、拖拽删除功能
Jan 05 Vue.js
vue-resource 拦截器interceptors使用详解
Jan 18 Vue.js
Vue单页面应用中实现Markdown渲染
Feb 14 Vue.js
vue-cli中实现响应式布局的方法
Mar 02 Vue.js
Vue + iView实现Excel上传功能的完整代码
Jun 22 Vue.js
VUE使用draggable实现组件拖拽
Apr 06 Vue.js
vue使用watch监听属性变化
Apr 30 Vue.js
vue/cli 配置动态代理无需重启服务的方法
May 20 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查询操作实现投票功能
2016/05/09 PHP
PHP应用跨时区功能的实现方法
2019/03/21 PHP
js解析与序列化json数据(一)json.stringify()的基本用法
2013/02/01 Javascript
js动态设置div的值下例子
2013/10/29 Javascript
jQuery中:last-child选择器用法实例
2014/12/31 Javascript
jQuery中end()方法用法实例
2015/01/08 Javascript
jQuery中position()方法用法实例
2015/01/16 Javascript
javascript中typeof操作符和constucor属性检测
2015/02/26 Javascript
jQuery使用$.ajax提交表单完整实例
2015/12/11 Javascript
js编写一个简单的产品放大效果代码
2016/06/27 Javascript
Vue动态实现评分效果
2017/05/24 Javascript
jQuery正则验证注册页面经典实例
2017/06/10 jQuery
nodejs实现的连接MySQL数据库功能示例
2018/01/25 NodeJs
Node.js进阶之核心模块https入门
2018/05/23 Javascript
微信小程序实现刷脸登录
2018/05/25 Javascript
Angular2使用SVG自定义图表(条形图、折线图)组件示例
2019/05/10 Javascript
微信小程序tab切换可滑动切换导航栏跟随滚动实现代码
2019/09/04 Javascript
layui-select动态选中值的例子
2019/09/23 Javascript
[02:57]2014DOTA2国际邀请赛-观众采访
2014/07/19 DOTA
Python简单实现TCP包发送十六进制数据的方法
2016/04/16 Python
Python实现图片转字符画的代码实例
2019/02/22 Python
使用Python做定时任务及时了解互联网动态
2019/05/15 Python
linux下安装python3和对应的pip环境教程详解
2019/07/01 Python
python matplotlib库绘制条形图练习题
2019/08/10 Python
希尔顿酒店官方网站:Hilton Hotels
2017/06/01 全球购物
Tod’s英国官方网站:意大利奢华手工制作手袋和鞋履
2019/03/15 全球购物
请解释流与文件有什么不同
2016/07/29 面试题
大学生职业生涯设计书
2014/01/02 职场文书
招聘单位介绍信
2014/01/14 职场文书
出国签证在职证明
2014/01/16 职场文书
十八大感想感言
2014/02/10 职场文书
学习雷锋演讲稿
2014/05/10 职场文书
还款承诺书范文
2014/05/20 职场文书
工作检讨书怎么写
2014/10/10 职场文书
python 实现两个变量值进行交换的n种操作
2021/06/02 Python
集英社今正式宣布 成立游戏公司“集英社Games”
2022/03/31 其他游戏