什么是axios?怎么使用axios封装Ajax?
学习目标
- 什么是axios
- 怎么使用axios封装Ajax
- 该如何使用Axios 封装 XHR 请求
什么是axios
Axios 是一个基于 Promise 的 HTTP 客户端,它可以在浏览器和 Node.js 环境中使用。Axios 提供了简单易用的 API,用于执行各种 HTTP 请求操作,如 GET、POST、PUT、DELETE 等。
以下是 Axios 的一些关键特性和功能:
- 基于 Promise:Axios 的 API 设计完全基于 Promise,这使得它能够很好地与 async/await 语法结合使用,从而简化了异步操作的处理。
- 请求和响应的拦截器:Axios 支持请求和响应的拦截器,允许你在请求发送前或响应接收后对其进行处理。这可以用于添加认证信息、处理错误、记录日志等。
- 自动转换数据:Axios 会自动将请求数据转换为请求体(例如,将 JavaScript 对象转换为 JSON 字符串),并自动解析响应数据(例如,将 JSON 字符串转换为 JavaScript 对象)。
- 取消请求:你可以使用 Axios 提供的取消令牌(CancelToken)来取消已发出的请求。
- 防止跨站请求伪造(XSRF):在浏览器环境中,Axios 可以自动从 cookies 中读取 XSRF 令牌,并将其添加到请求头中,以防止跨站请求伪造攻击。
- 配置灵活性:你可以通过创建一个 Axios 实例来配置其默认设置,如基础 URL、超时时间、请求头等。这使得在不同的项目或不同的请求中重用相同的配置变得更加容易。
- 浏览器和 Node.js 兼容:Axios 可以在所有现代浏览器中运行,并且也支持在 Node.js 环境中使用,这使得它成为一个跨平台的 HTTP 客户端。
- 小型且高效:Axios 的代码库相对较小,但它提供了丰富的功能,使得它成为许多 Web 应用程序和 API 的首选 HTTP 客户端。
总的来说,Axios 是一个功能强大、易于使用且灵活的 HTTP 客户端,它能够帮助开发者以简洁和高效的方式处理 HTTP 请求和响应。
怎么使用axios封装Ajax
使用 Axios 封装 AJAX 请求是一个常见的做法,它可以帮助你简化代码、统一请求格式和处理逻辑。以下是一个基本的 Axios 封装示例,包括请求和响应的拦截器、错误处理以及配置默认请求选项。
首先,你需要安装 Axios。如果你还没有安装它,可以使用 npm 或 yarn 进行安装:
npm install axios
# 或者
yarn add axios
然后,你可以创建一个新的文件(例如 axiosInstance.js)来封装 Axios 实例:
// axiosInstance.js
import axios from 'axios';// 创建一个 Axios 实例
const axiosInstance = axios.create({baseURL: 'https://api.example.com', // 你的 API 基础 URLtimeout: 10000, // 请求超时时间headers: {'Content-Type': 'application/json', // 默认请求头},
});// 请求拦截器
axiosInstance.interceptors.request.use(config => {// 在发送请求之前做些什么,例如添加认证令牌// config.headers.Authorization = `Bearer ${token}`;return config;},error => {// 对请求错误做些什么return Promise.reject(error);}
);// 响应拦截器
axiosInstance.interceptors.response.use(response => {// 对响应数据做点什么,例如统一处理错误状态码if (response.status >= 200 && response.status < 300) {return response.data; // 返回实际数据} else {// 处理错误响应,例如显示错误消息或抛出错误return Promise.reject(new Error(response.statusText));}},error => {// 对响应错误做点什么,例如显示错误消息或抛出错误if (error.response) {// 服务器返回了一个状态码,且状态码触发了错误处理console.error('Error Response:', error.response.data);console.error('Error Status:', error.response.status);console.error('Error Headers:', error.response.headers);} else if (error.request) {// 请求已经发出,但没有收到响应console.error('Error Request:', error.request);} else {// 其他错误(例如,设置请求时发生的错误)console.error('Error Message:', error.message);}return Promise.reject(error);}
);// 导出 Axios 实例
export default axiosInstance;
现在,你可以在你的应用程序中使用这个封装的 Axios 实例来发送 AJAX 请求。例如:
// someComponent.js 或 anyOtherFile.js
import axiosInstance from './axiosInstance';// 发送一个 GET 请求
axiosInstance.get('/some-endpoint').then(data => {console.log('Data:', data);}).catch(error => {console.error('Error:', error);});// 发送一个 POST 请求
axiosInstance.post('/another-endpoint', { key: 'value' }).then(data => {console.log('Data:', data);}).catch(error => {console.error('Error:', error);});
这个封装示例提供了基本的功能,但你可以根据需要进行扩展。例如,你可以添加更多的请求拦截器来处理身份验证令牌、全局错误处理逻辑、请求重试机制等。
该如何使用Axios 封装 XHR 请求
实际上,Axios 本身就是一个基于 Promise 的 HTTP 客户端,它已经在内部封装了 XMLHttpRequest (XHR) 的复杂细节,因此你不需要直接使用或封装 XHR。使用 Axios,你可以更方便地发送 HTTP 请求,并处理响应和错误。
不过,如果你想要了解如何使用 Axios 来替代传统的 XHR 请求,或者想要在你的项目中通过 Axios 来封装一些常用的请求逻辑,以下是一个基本的指南:
- 安装 Axios:
首先,你需要确保你的项目中已经安装了 Axios。如果还没有安装,可以使用 npm 或 yarn 进行安装。
npm install axios
# 或者
yarn add axios
- 创建 Axios 实例(可选):
你可以创建一个 Axios 实例来配置一些默认的设置,比如基础 URL、超时时间、请求头等。这类似于传统 XHR 中的“打开”一个连接并设置请求头。
const axiosInstance = axios.create({baseURL: 'https://api.example.com',timeout: 10000,headers: {'X-Custom-Header': 'foobar'}
});
- 发送请求:
使用 Axios 的方法(如 get、post、put、delete 等)来发送 HTTP 请求。这些方法会返回一个 Promise,你可以使用 .then() 和 .catch() 来处理响应和错误。
// 使用默认的 axios
axios.get('/users').then(response => {console.log(response.data);}).catch(error => {console.error('Error fetching users:', error);});// 使用自定义的 axios 实例
axiosInstance.post('/users', {name: 'John Doe',email: 'john.doe@example.com'
}).then(response => {console.log('User created:', response.data);}).catch(error => {console.error('Error creating user:', error);});
- 配置拦截器(可选):
你可以配置请求拦截器和响应拦截器来在请求发送之前或响应到达之后执行一些逻辑。这类似于传统 XHR 中的“设置请求头”和“处理响应”。
axiosInstance.interceptors.request.use(config => {// 在发送请求之前做些什么,比如添加认证 tokenconst token = localStorage.getItem('token');if (token) {config.headers['Authorization'] = `Bearer ${token}`;}return config;
}, error => {// 对请求错误做些什么return Promise.reject(error);
});axiosInstance.interceptors.response.use(response => {// 对响应数据做些什么return response.data;},error => {// 对响应错误做些什么if (error.response) {// 处理 HTTP 状态码错误}return Promise.reject(error);}
);
- 处理响应和错误:
使用 .then() 方法来处理成功的响应,使用 .catch() 方法来处理错误。你也可以使用 async/await 语法来更简洁地处理异步请求。
async function fetchUsers() {try {const response = await axiosInstance.get('/users');console.log(response.data);} catch (error) {console.error('Error fetching users:', error);}
}fetchUsers();
总之,使用 Axios 封装 HTTP 请求可以大大简化你的代码,并提升可读性和可维护性。你不需要直接处理 XHR 的复杂细节,因为 Axios 已经为你处理了这些。
相关文章:
什么是axios?怎么使用axios封装Ajax?
学习目标 什么是axios怎么使用axios封装Ajax该如何使用Axios 封装 XHR 请求 什么是axios Axios 是一个基于 Promise 的 HTTP 客户端,它可以在浏览器和 Node.js 环境中使用。Axios 提供了简单易用的 API,用于执行各种 HTTP 请求操作,如 GET、P…...
Web前端学习_CSS盒子模型
content padding border margin <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>CSS盒子模型</title><style></style> </head> <body> <div class"demo&quo…...
JAVA项目-------医院挂号系统
1,项目目的 1、科室管理:新增科室,删除科室(如果有医生在,则不能删除该科室),修改科室。 2、医生管理:录入医生信息,以及科室信息。修改医生信息(主要是修改…...
[工具分享] 根据Excel数据根据Word文档模板,批量创建生成Word文档并重命名,方便快速查找打印
前几天交楼的小姐姐要多份Word文档合同打印给客户,那么100份就需要修改100次 上面好多都是模板的制式文件,里面的部分数据都是要根据实际值来变动的, 那么有没有快速的方法来操作呢,还是只能一个个手动的改,又容易出…...
Redis的管道操作
在现代应用程序中,Redis作为一种高性能的内存数据库,被广泛用于缓存、消息队列、实时分析等场景。为了进一步提高Redis的性能,Redis提供了管道(Pipeline)操作,允许客户端将多个命令一次性发送到服务器&…...
IT监控 | Oracle云监控全解析
Oracle云(Oracle Cloud)是Oracle公司提供的云服务平台,涵盖了IaaS、PaaS、SaaS和DaaS,支持企业在云中构建、部署、集成和扩展应用,为企业提供了管理服务器、应用程序、存储、网络和数据中心的全面控制能力。 跟踪Oracle云基础设施的关键组件将…...
前端面试题-1(详解事件循环)
1.了解浏览器的进程模型 1.什么是进程? 程序运行需要有它自己专属的内存空间,可以把这块内存空间简单的理解为进程 每个应用至少有一个进程,进程之间相互独立,即使要通信,也需要双方同意。 2.什么是线程?…...
Redis(5):哨兵
一、作用和架构 1. 作用 在介绍哨兵之前,首先从宏观角度回顾一下Redis实现高可用相关的技术。它们包括:持久化、复制、哨兵和集群,其主要作用和解决的问题是: 1)持久化:持久化是最简单的高可用方法(有时甚…...
【人工智能】Transformers之Pipeline(二十五):图片特征抽取(image-feature-extraction)
目录 一、引言 二、图片特征抽取(image-feature-extraction) 2.1 概述 2.2 google/ViT 2.3 pipeline参数 2.3.1 pipeline对象实例化参数 2.3.2 pipeline对象使用参数 2.4 pipeline实战 2.5 模型排名 三、总结 一、引言 pi…...
podman 源码 5.3.1编译
1. 构建环境 在麒麟V10服务器操作系统上构建:Kylin-Server-V10-GFB-Release-2204-Build03-ARM64.iso。由于只是编译 podman 源码,没必要特地在物理机或服务上安装一个这样的操作系统,故采用在虚拟机里验证。 2. 安装依赖 参考资料…...
矩阵重新排列——rot90函数
通过 r o t 90 rot90 rot90函数可以将矩阵进行旋转 用法: r o t 90 ( a , k ) rot90(a,k) rot90(a,k)将矩阵 a a a按逆时针方向旋转 k 9 0 ∘ k\times90^\circ k90∘...
Leetcode 51 N Queens Leetcode N Queens II
题意 给定一个数字 n n n,形成n*n的棋盘,棋盘上放n个皇后,确保皇后之间不会相互吃(皇后可以直线吃,斜线吃) 链接 https://leetcode.com/problems/n-queens/description/ 思考 这道题只能暴力枚举所有的…...
0.查找命令
目录 🍉 find - 查找文件 🍇 grep 🍓 which 🍈locate 总结: 🍉 find - 查找文件 # 语法 # find [搜索范围] [选项] # 选项 # -name<查询方式> 按照指定的文件名查找模式查找文件 # …...
HarmonyOS-初级(一)
文章目录 初级核心技术理念函数的声明和使用类的声明和使用接口声明和使用声明式UI的特征 🏡作者主页:点击! 🤖HarmonyOS专栏:点击! ⏰️创作时间:2024年11月28日12点50分 初级 HAP可以分为静…...
Oracle 11gR2 坏块修复实例一则
背景 前段时间在 Oracle 11gR2 数据库中发现了坏块问题。环境是 64 位 Linux 平台。本文将详细介绍如何使用 DBMS_REPAIR 进行在线修复,当然也可以基于备份和 RMAN 的修复方法这里暂时不做介绍。 发现坏块 1. 从 alert.log 中发现错误 在 alert.log 文件中发现了…...
解决FinalShell 连接virtual box安装的Linux centos/7系统 一直让输入密码,输入什么密码都没用
问题描述: virtual box安装的Linux centos/7系统默认只允许ssh登录方式,需要配置允许账号密码登录 先登录root账号(一定要是root):初始密码为vagrant su 修改ssh配置文件: vi /etc/ssh/sshd_config 修改…...
华为E9000刀箱(HWE9000V2)服务器硬件监控指标解读
随着数据中心规模的不断扩大,服务器的稳定性和可靠性变得尤为重要。华为E9000刀箱(HWE9000V2)作为一款高性能的服务器设备,其硬件状态的实时监控对于保障业务的连续性和系统的稳定运行至关重要。 监控易作为一款专业的IT基础设施监…...
Python基础学习-12匿名函数lambda和map、filter
目录 1、匿名函数: lambda 2、Lambda的参数类型 3、map、 filter 4、本节总结 1、匿名函数: lambda 1)语法: lambda arg1, arg2, …, argN : expression using arg 2) lambda是一个表达式,而不是一个语…...
民安:助力提升城市安全水平
随着城市化进程的加速,平安城市的创建成为了社会治理的重要议题。为了解公众对平安城市创建的看法和评价,为提升城市安全水平提供参考,近期某市委托民安智库专业市场调查公司开展了一次安全感满意度调查。 本次调查围绕公共安全、个人安全、…...
Apache Zeppelin:一个基于Web的大数据可视化分析平台
今天给大家推荐一下 Apache Zeppelin,它是一个基于 Web 的交互式数据接入、数据分析、数据可视化以及协作文档 Notebook,类似于 Jupyter Notebook。 Apache Zeppelin 支持使用 SQL、Java、Scala、Python、R 等编程语言进行数据处理和分析,同时…...
用STM32的TIM1和GPIO中断,手把手教你实现带霍尔BLDC的平稳启动与调速(附PID代码)
STM32实战:基于霍尔传感器的BLDC电机六步换相与PID调速全解析 在工业自动化、无人机和机器人等领域,无刷直流电机(BLDC)凭借其高效率、长寿命和低噪音特性成为首选驱动方案。本文将深入探讨如何利用STM32的TIM1高级定时器和GPIO中断实现带霍尔传感器的BL…...
SINAMICS V90伺服驱动器故障代码大全
SINAMICS V90伺服驱动器在运行过程中可能出现故障,导致设备停机。用户可通过BOP面板或调试软件查看故障代码,并根据以下信息判断故障原因及处理方法。序号报警号信息故障信息可能原因处理方法1F1000内部软件错误出现了一个内部软件错误。分析故障缓冲器为…...
AI工具导航与实战指南:从分类体系到选型策略
1. 项目概述:AI-Infinity,一个前沿AI工具的探索者指南如果你和我一样,对AI领域层出不穷的新工具感到既兴奋又头疼,那么这个项目绝对值得你花时间深入了解。AI-Infinity,这个由开发者meetpateltech维护的GitHub仓库&…...
为什么92%的SaaS团队在3个月内切换了语音服务商?——ElevenLabs与PlayAI在WebRTC集成、WebAssembly兼容性及低功耗端侧部署的实战踩坑全记录
更多请点击: https://intelliparadigm.com 第一章:语音合成服务商切换潮的底层动因解构 近年来,大量智能客服、有声阅读与车载交互系统密集启动 TTS(Text-to-Speech)服务商迁移项目。这一现象并非源于单一技术迭代&am…...
基于Vue 3与Express的私有化ChatGPT Web客户端部署指南
1. 项目概述与核心价值最近在折腾一个自用的AI对话工具,核心需求很简单:想在一个自己完全掌控的界面上,方便地使用大语言模型,比如ChatGPT的API。市面上虽然有很多现成的网页应用,但要么功能太臃肿,要么部署…...
004 LVGL应用场景与案例概览
004 LVGL应用场景与案例概览 上周帮一个做智能家居的朋友调屏,他用的STM32F407+4.3寸RGB屏,LVGL跑得挺欢,但一加上WiFi联网和MQTT协议栈,屏幕刷新就开始卡顿,触摸响应延迟明显。我打开他的代码一看,好家伙,lv_task_handler()直接放在主循环里裸奔,没有任何优先级管理。…...
Python全栈实战:前后端分离开发核心要点
后端API搭建FastAPI与Flask是Python全栈开发的主流后端框架选择。两者均支持RESTful API开发,但适用场景不同:FastAPI代码示例(高性能方案):from fastapi import FastAPI app FastAPI()app.get("/items/{item_id…...
CSS 容器查询完全指南
CSS 容器查询完全指南 引言 CSS 容器查询(Container Queries)是 CSS 规范中的一项革命性特性,它允许开发者根据容器的尺寸而非视口尺寸来应用样式。本文将深入探讨容器查询的各种用法和高级技巧。 基础概念回顾 容器查询 vs 媒体查询 特…...
CSS 混合模式完全指南
CSS 混合模式完全指南 引言 CSS 混合模式(Blend Modes)是一种强大的视觉效果工具,它允许你控制多个元素或图层如何混合在一起。本文将深入探讨各种混合模式的用法和高级技巧。 混合模式类型 基础混合模式 模式效果描述normal默认模式…...
绝地求生罗技鼠标宏实战指南:5步实现高效压枪技巧
绝地求生罗技鼠标宏实战指南:5步实现高效压枪技巧 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 对于《绝地求生》玩家来说…...
