当前位置: 首页 > news >正文

如何封装一个axios,封装axios有哪些好处

什么是Axios

Axios 是一个基于 Promise 的 HTTP 客户端,用于在浏览器和 Node.js 中发送异步网络请求。它简化了发送 GETPOSTPUTDELETE 等请求的过程,并且支持请求拦截、响应拦截、取消请求和自动处理 JSON 数据等功能。

为什么要封装Axios

封装 Axios 可以统一管理项目中的网络请求,简化代码并提高维护性和可扩展性。通过请求和响应拦截器,我们可以处理鉴权、错误处理等复杂逻辑,同时还能方便地应对不同的网络请求需求。具体来说,封装 Axios 可以带来以下好处:

  • 统一处理请求和响应:集中处理错误、鉴权、日志记录和通用配置。
  • 简化代码:避免在每个模块中重复配置请求头、超时等参数。
  • 提升可维护性:在一个地方集中管理全局配置,便于后续修改和维护。
  • 处理多样需求:实现请求节流、取消重复请求等功能,满足不同场景的需求。

通过这些优化,封装 Axios 能够显著提升项目的整体质量和开发效率。

如何封装Axios

在Vue大型项目中使用Axios,可以按照以下步骤进行:

1. 全局封装Axios

首先,创建一个单独的文件 request.js 来封装 Axios 的全局配置:

import axios from 'axios';// 创建 Axios 实例
const axiosInstance = axios.create({baseURL: process.env.VUE_APP_API_BASE_URL, // 配置基础URLtimeout: 5000, // 设置超时时间headers: { 'Content-Type': 'application/json' }
});// 请求拦截器
axiosInstance.interceptors.request.use(config => {const token = localStorage.getItem('token');if (token) {config.headers.Authorization = `Bearer ${token}`; // 统一添加Authorization头}return config;},error => Promise.reject(error)
);// 响应拦截器
axiosInstance.interceptors.response.use(response => response.data,error => {if (error.response.status === 401) {// 处理未授权}return Promise.reject(error);}
);export default axiosInstance;
2. Vue项目中全局引入Axios

main.js 中全局引入 Axios 封装:

import axiosInstance from './utils/request';Vue.prototype.$http = axiosInstance;

这样你可以在任意 Vue 组件中使用 this.$http 发起网络请求。

3. 模块化管理API

对于大型项目,将API请求模块化管理,可以在 api 文件夹中按功能模块划分文件:

例如在 api/user.js

import axios from '../utils/request';export function getUserInfo(params) {return axios.get('/user/info', params);
}export function updateUser(data) {return axios.post('/user/update', data);
}
4. 在组件中使用Axios

在组件中直接调用封装好的API方法:

import { getUserInfo } from '@/api/user';export default {data() {return {userInfo: null};},created() {const parmas = {name: 'admin',password: '123456'​​}this.fetchUserInfo(parmas ​);},methods: {async fetchUserInfo(params​) {try {this.userInfo = await getUserInfo(params​);} catch (error) {console.error('获取用户信息失败', error);}}}
};
http://www.lryc.cn/news/476747.html

相关文章:

  • java的批量update
  • go语言连续监控事件并回调处理
  • 1.探索WebSocket:实时网络的心跳!
  • uniapp学习(010-2 实现抖音小程序上线)
  • 测试和实施面试题收集
  • 【Vue3】一文全览基础语法-案例程序及配图版
  • 【OpenSearch】安装部署OpenSearch和OpenSearch-Dashboard
  • 【系统架构设计师】2023年真题论文: 论软件可靠性评价的设计与实现(包括和素材和论文)
  • 教程:使用 InterBase Express 访问数据库(二)
  • Windows密码的网络认证---基于挑战响应认证的NTLM协议
  • fpga 常量无法改变
  • 【HarmonyOS NEXT】如何给未知类型对象定义类型并使用递归打印所有的Key
  • RuoYi 样例框架运行步骤(测试项目自用,同学可自取)
  • Java进程CPU飙高排查
  • conda的对应环境下安装cuda11.0和对应的cudnn
  • 微服务透传日志traceId
  • 【自然语言处理与大模型】大模型(LLM)基础知识②
  • 新能源汽车的未来:车载电源与V2G技术的前景
  • Git 本地操作(2)
  • 项目管理软件:5款甘特图工具测评
  • Unreal5从入门到精通之如何在指定的显示器上运行UE程序
  • 【Spring MVC】DispatcherServlet 请求处理流程
  • 【优选算法】——二分查找!
  • leetcode hot100【LeetCode 300. 最长递增子序列】java实现
  • sql注入——靶场Less1
  • docker file容器化部署Jenkins(一)
  • ArkTS组件继承的高级用法
  • 第十二章 spring Boot+shiro权限管理
  • jmeter基础01-3_环境准备-Linux系统安装jdk
  • 数字证书的简单记录