什么是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 等编程语言进行数据处理和分析,同时…...

eNSP-Cloud(实现本地电脑与eNSP内设备之间通信)
说明: 想象一下,你正在用eNSP搭建一个虚拟的网络世界,里面有虚拟的路由器、交换机、电脑(PC)等等。这些设备都在你的电脑里面“运行”,它们之间可以互相通信,就像一个封闭的小王国。 但是&#…...
java 实现excel文件转pdf | 无水印 | 无限制
文章目录 目录 文章目录 前言 1.项目远程仓库配置 2.pom文件引入相关依赖 3.代码破解 二、Excel转PDF 1.代码实现 2.Aspose.License.xml 授权文件 总结 前言 java处理excel转pdf一直没找到什么好用的免费jar包工具,自己手写的难度,恐怕高级程序员花费一年的事件,也…...
如何为服务器生成TLS证书
TLS(Transport Layer Security)证书是确保网络通信安全的重要手段,它通过加密技术保护传输的数据不被窃听和篡改。在服务器上配置TLS证书,可以使用户通过HTTPS协议安全地访问您的网站。本文将详细介绍如何在服务器上生成一个TLS证…...

如何在最短时间内提升打ctf(web)的水平?
刚刚刷完2遍 bugku 的 web 题,前来答题。 每个人对刷题理解是不同,有的人是看了writeup就等于刷了,有的人是收藏了writeup就等于刷了,有的人是跟着writeup做了一遍就等于刷了,还有的人是独立思考做了一遍就等于刷了。…...

10-Oracle 23 ai Vector Search 概述和参数
一、Oracle AI Vector Search 概述 企业和个人都在尝试各种AI,使用客户端或是内部自己搭建集成大模型的终端,加速与大型语言模型(LLM)的结合,同时使用检索增强生成(Retrieval Augmented Generation &#…...

html css js网页制作成品——HTML+CSS榴莲商城网页设计(4页)附源码
目录 一、👨🎓网站题目 二、✍️网站描述 三、📚网站介绍 四、🌐网站效果 五、🪓 代码实现 🧱HTML 六、🥇 如何让学习不再盲目 七、🎁更多干货 一、👨…...

排序算法总结(C++)
目录 一、稳定性二、排序算法选择、冒泡、插入排序归并排序随机快速排序堆排序基数排序计数排序 三、总结 一、稳定性 排序算法的稳定性是指:同样大小的样本 **(同样大小的数据)**在排序之后不会改变原始的相对次序。 稳定性对基础类型对象…...

基于IDIG-GAN的小样本电机轴承故障诊断
目录 🔍 核心问题 一、IDIG-GAN模型原理 1. 整体架构 2. 核心创新点 (1) 梯度归一化(Gradient Normalization) (2) 判别器梯度间隙正则化(Discriminator Gradient Gap Regularization) (3) 自注意力机制(Self-Attention) 3. 完整损失函数 二…...

push [特殊字符] present
push 🆚 present 前言present和dismiss特点代码演示 push和pop特点代码演示 前言 在 iOS 开发中,push 和 present 是两种不同的视图控制器切换方式,它们有着显著的区别。 present和dismiss 特点 在当前控制器上方新建视图层级需要手动调用…...

计算机基础知识解析:从应用到架构的全面拆解
目录 前言 1、 计算机的应用领域:无处不在的数字助手 2、 计算机的进化史:从算盘到量子计算 3、计算机的分类:不止 “台式机和笔记本” 4、计算机的组件:硬件与软件的协同 4.1 硬件:五大核心部件 4.2 软件&#…...