axios 封装,API接口统一管理

news/2024/11/7 18:04:59/

分享一个自己封装的 axios 网络请求

主要的功能及其优点:

将所有的接口放在一个文件夹中管理(api.js)。并且可以支持动态接口,就是 api.js 文件中定义的接口可以使用 :xx 占位,根据需要动态的改变。动态接口用法模仿的是vue的动态路由,如果你不熟悉动态路由可以看看我的这篇文章:Vue路由传参详解(params 与 query)

1.封装请求:

  1. 首先在 src 目录下创建 http 目录。继续在 http 目录中创建 api.js 文件与 index.js 文件。
  2. 然后再 main.js 文件中导入 http 目录下的 index.js 文件。将请求注册为全局组件。
  3. 将下面封装所需代码代码粘到对应的文件夹

2.基本使用:

//示例:获取用户列表
getUsers() {const { data } = await this.$http({url: 'users' //这里的 users 就是 api.js 中定义的“属性名”})
},
复制代码

3.动态接口的使用:

//示例:删除用户
deleteUser() {const { data } = await this.$http({method: 'delete',//动态接口写法模仿的是vue的动态路由//这里 params 携带的是动态参数,其中 “属性名” 需要与 api 接口中的 :id 对应//也就是需要保证携带参数的 key 与 api 接口中的 :xx 一致url: {// 这里的 name 值就是 api.js 接口中的 “属性名”name: 'usersEdit',params: {id: userinfo.id,},},})
},
复制代码

4.不足:

封装的请求只能这样使用 this.$http() 。不能 this.$http.get()this.$http.delete()

由于我感觉使用 this.$http() 这种就够了,所以没做其他的封装处理

如果你有更好的想法可以随时联系我

如下是封装所需代码:

  • api.js 管理所有的接口
// 如下接口地址根据自身项目定义
const API = {// base接口baseURL: 'http://127.0.0.1:8888/api/private/v1/',// 用户users: '/users',// “修改”与“删除”用户接口(动态接口)usersEdit: '/users/:id',
}
​
export default API
​
复制代码
  • index.js 逻辑代码
// 这里请求封装的主要逻辑,你可以分析并将他优化,如果有更好的封装方法欢迎联系我Q:2356924146
import axios from 'axios'
import API from './api.js'
​
const instance = axios.create({baseURL: API.baseURL,timeout: '8000',method: 'GET'
})
​
// 请求拦截器
instance.interceptors.request.use(config => {// 此处编写请求拦截代码,一般用于加载弹窗,或者每个请求都需要携带的tokenconsole.log('正在请求...')// 请求携带的tokenconfig.headers.Authorization = sessionStorage.getItem('token')return config},err => {console.log('请求失败', err)}
)
​
// 响应拦截器
instance.interceptors.response.use(res => {console.log('响应成功')//该返回对象会绑定到响应对象中return res},err => {console.log('响应失败', err)}
)
​
//options 接收 {method, url, params/data}
export default function(options = {}) {return instance({method: options.method,url: (function() {const URL = options.url
​if (typeof URL === 'object') {//拿到动态 urllet DynamicURL = API[URL.name]
​//将 DynamicURL 中对应的 key 进行替换for (const key of Object.keys(URL.params)) {DynamicURL = DynamicURL.replace(':' + key, URL.params[key])}
​return DynamicURL} else {return API[URL]}})(),//获取查询字符串参数params: options.params,//获取请求体字符串参数data: options.data})
}
​
复制代码
  • main.js 将请求注册为全局组件
import Vue from 'vue'
​
// 会自动导入 http 目录中的 index.js 文件
import http from './http'
​
Vue.prototype.$http = http


http://www.ppmy.cn/news/31673.html

相关文章

华为OD机试题 - 最少数量线段覆盖(JavaScript)| 机考必刷

更多题库,搜索引擎搜 梦想橡皮擦华为OD 👑👑👑 更多华为OD题库,搜 梦想橡皮擦 华为OD 👑👑👑 更多华为机考题库,搜 梦想橡皮擦华为OD 👑👑👑 华为OD机试题 最近更新的博客使用说明本篇题解:最少数量线段覆盖题目输入输出示例一输入输出说明Code解题思路版…

Element-UI实现复杂table表格结构

Element-UI组件el-table用于展示多条结构类似的数据,可对数据进行排序、筛选、对比或其他自定义操作。将使用到以下两项,来完成今天demo演示:多级表头:数据结构比较复杂的时候,可使用多级表头来展现数据的层次关系。合…

vscode环境配置(支持跳转,阅读linux kernel)

目录 1.卸载clangd插件 2.安装C插件 3. 搜索框内输入 “intell”,将 C_Cpp:Intelli Sense Engine 开关设置为 Default。 4.ubuntu安装global工具 5.vscode安装插件 6.验证是否生效 7.建立索引 1.卸载clangd插件 在插件管理中卸载clangd插件 2.安…

海思ubootsd卡协议

在start_armboot()函数中调用mmc_initialize(0)初始化mmc;最终调用到int hi_mci_initialize(unsigned int dev_num)函数;内容如下:static int hi_mci_initialize(unsigned int dev_num) {struct mmc *mmc NULL;static struct himci_host *host;unsigned int regval;unsigned l…

Linux C++ 多线程高并发服务器实战项目一

文章目录1、项目介绍2、项目流程2.1、环境变量搬家2.2、设置进程title2.3、信号初始化2.4、开始监听端口2.5、创建守护进程2.6、创建子进程1、项目介绍 1、按照包头包体的格式收发数据包,解决粘包的问题 2、非常完整的多线程高并发服务器 3、根据收到数据包执行&…

docker环境mongoexport导出MongoDB数据

因为安全问题,服务器屏蔽了mongoDB给外部客户端调用,所以我们就不可以使用Navicat等客户端连接,操作确实不方便。最近需要导出一些mongoDB数据,只能采用命令的方式导出数据,需要借助mongoexport这个命令,命…

SPI 接口OLED 模块 - 兼容5V 和3.3V 电平

PCB 布局参考了老王0.8元128x32OLED显示屏转接板,开源项目地址:老王0.8元128x32OLED 模块-部分优化。 老王家买的屏幕放了快一年了,终于还是决定整个单独的模块,之前一直打算集成到开发板上的,不太灵活。相比那个转接板…

【学习笔记】人工智能哲学研究:《心智、语言和机器》

关于人工智能哲学,我曾在这篇文章里 【脑洞大开】从哲学角度看人工智能:介绍徐英瑾的《心智、语言和机器》 做过介绍。图片来源:http://product.dangdang.com/29419969.html在我完成了一些人工智能相关的工作以后,我再来分享《心智…