axios二次封装教程

优点

axios二次封装接口,方便管理所有接口,提高可维护性


具体操作步骤

一、安装 axios

npm i axios

二、创建 api 文件夹

在这里插入图片描述

1.request.js

用于管理请求配置

// 引入 axios
import axios from 'axios'

const requests = axios.create({
    // 配置基础路径
    baseURL:'http://localhost:3000',
    timeout:3000,
    // 请求头
    /* headers:{} */
})

// 配置拦截器
requests.interceptors.request.use(config => {
    // 请求带token
    /* config.headers.Authorization = window.sessionStorage.getItem('token') */
    return config
})

// 对应拦截器
requests.interceptors.response.use((res) => {
    // 请求成功的回调函数
    return  res.data;
},() => {
    // 请求失败的回调函数
    return Promise.reject('fail')
})
// 对外暴露
export default requests;

2.index.js

用于管理所有的请求,这里演示一个test接口,由于request.js 配置了 baseURL,所以这里的url只需要填写 /test

// 导入封装好的axios请求文件
import requests from "./request";

// 测试接口
export const Test = () => {
    return  requests({
        url: '/test',
        method: 'GET',
    })
}

3.在页面中调用接口

先引入接口文件,因为接口文件名字是index,所以引入时可以省略

import {Test} from "../api"

因为 axios 返回的是 promise 对象,所以用await进行解析

// test 函数,触发就发送请求
async test() {
	try {
		// 调用接口
		let a = await Test()
		// 输出请求后的返回值
		console.log(a)
	} catch(error){
		// 请求失败的回调
		console.log(error)
	}
}

4.请求成功时

在这里插入图片描述

5.请求失败时

在这里插入图片描述

总结

把所有接口都放在一起,可以便捷管理。可以像本文一样按需引入,如果是vue项目的话也可以直接在入口文件中导入,变成全局。

多个接口演示:
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

holden丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值