使用Axios函数库进行网络请求的使用指南
目录
- 前言
- 1. 什么是Axios
- 2. Axios的引入方式
- 2.1 通过CDN直接引入
- 2.2 在模块化项目中引入
- 3. 使用Axios发送请求
- 3.1 GET请求
- 3.2 POST请求
- 4. Axios请求方式别名
- 5. 使用Axios创建实例
- 5.1 创建Axios实例
- 5.2 使用实例发送请求
- 6. 使用async/await简化异步请求
- 6.1 获取所有文章数据
- 6.2 捕获异常
- 7. 将Axios提取成模块
- 8. 小结
前言
在现代的前端开发中,API调用是实现前后端数据交互的重要环节。而在众多的HTTP库中,Axios以其简洁的语法、丰富的功能和易于扩展的特性,成为了开发者的首选。本篇文章将深入介绍Axios的使用方法,包括如何引入、基本使用方法、请求方式别名、异步操作等,并通过示例代码帮助读者快速掌握Axios。
1. 什么是Axios
Axios是一个基于Promise的HTTP库,可以用于浏览器和Node.js环境下的网络请求。它支持多种请求方式(GET、POST、PUT、DELETE等),支持Promise语法,并且兼容ES7的async/await语法。Axios能够轻松发送异步请求,处理JSON格式数据,还支持自动转换请求和响应数据格式、拦截请求与响应、取消请求等高级功能。
2. Axios的引入方式
在项目中使用Axios有多种引入方式,主要包括通过CDN直接引入和在模块化项目中通过npm安装。
2.1 通过CDN直接引入
在HTML文件中,可以直接使用script标签引入Axios的CDN链接:
<script src="https://cdn.jsdelivr.net/npm/axios/dist/axios.min.js"></script>
通过这种方式引入后,Axios会挂载到全局的axios
变量上,可以直接使用axios
对象进行请求操作。
2.2 在模块化项目中引入
对于前端开发中常见的模块化项目(如基于Webpack、Vite构建的项目),推荐通过npm安装Axios:
npm install axios
安装完成后,在需要的文件中通过import
导入:
import axios from 'axios';
这样可以确保项目依赖的管理,同时避免全局污染。
3. 使用Axios发送请求
Axios支持多种HTTP请求方法,开发者可以根据具体需求选择不同的方法来发送请求。最基本的请求方法为GET和POST,这两者涵盖了大多数的使用场景。
3.1 GET请求
GET请求用于从服务器获取数据。例如,我们希望获取所有文章数据:
axios.get('http://localhost:8080/article/getAll').then(response => {console.log(response.data);}).catch(error => {console.error(error);});
在上述代码中,通过axios.get()
发送请求,若请求成功,则可以通过response.data
获取服务器返回的数据;若失败,则进入catch
方法进行错误处理。
3.2 POST请求
POST请求用于向服务器发送数据,一般用于提交表单或其他信息。例如:
axios.post('http://localhost:8080/article/create', {title: 'Axios使用指南',content: '本文详细介绍了Axios的使用方法...'
}).then(response => {console.log(response.data);}).catch(error => {console.error(error);});
axios.post()
的第一个参数是请求URL,第二个参数是请求体,通常以JSON格式传递。
4. Axios请求方式别名
为了简化代码,Axios提供了所有常用请求方式的别名,开发者可以直接使用这些别名来发送相应的请求。
请求方式 | 别名 | 说明 |
---|---|---|
GET | axios.get(url, config) | 用于获取数据 |
POST | axios.post(url, data, config) | 提交数据 |
PUT | axios.put(url, data, config) | 更新资源 |
DELETE | axios.delete(url, config) | 删除资源 |
这些别名方法的参数包括URL、请求数据、请求配置(可选),能够满足不同的需求。通过这些别名,Axios进一步提升了开发效率。
5. 使用Axios创建实例
在项目中频繁调用API时,为了避免重复编写baseURL等信息,我们可以创建Axios实例。下面通过代码示例展示如何创建一个带有基础URL的Axios实例。
5.1 创建Axios实例
首先,定义一个公共的baseURL前缀,然后通过axios.create()
创建一个实例:
const baseURL = 'http://localhost:8080';
const instance = axios.create({baseURL: baseURL
});
通过instance
可以直接调用指定API而不需要重复写baseURL
。
5.2 使用实例发送请求
实例创建完成后,就可以通过instance
来发送请求:
instance.get('/article/getAll').then(response => {console.log(response.data);}).catch(error => {console.error(error);});
在这里,/article/getAll
是相对路径,Axios会自动拼接baseURL
,构成完整的URL并发送请求。
6. 使用async/await简化异步请求
在Axios中,Promise的语法已经非常简洁,但在一些复杂场景下,async/await的同步风格可以使代码逻辑更为直观。以下是使用async/await发送请求的示例。
6.1 获取所有文章数据
我们可以将获取文章列表的功能封装成一个异步函数:
export async function articleGetAllService() {try {const response = await instance.get('/article/getAll');return response.data;} catch (error) {console.error(error);}
}
在这个例子中,通过await
等待instance.get()
的结果,并在返回前检查是否发生错误。这种方式能够同步等待服务器响应,更加符合人类的阅读逻辑。
6.2 捕获异常
async/await同样支持try...catch
进行错误捕获,便于进行统一的错误处理。例如,在请求失败时,可以在控制台输出错误信息或提示用户重新尝试。
7. 将Axios提取成模块
在大型项目中,建议将Axios相关的代码集中到一个模块中,这样有助于管理API调用。以下是一个简单的Axios服务模块示例:
// apiService.js
import axios from 'axios';const baseURL = 'http://localhost:8080';
const instance = axios.create({baseURL: baseURL
});// 获取所有文章数据的函数
export async function articleGetAllService() {try {const response = await instance.get('/article/getAll');return response.data;} catch (error) {console.error(error);}
}
这个模块包含Axios实例的创建和API调用函数的封装,使用时只需在其他文件中导入模块即可。这样可以提高代码的可维护性和复用性。
8. 小结
在现代前端开发中,Axios提供了强大而灵活的HTTP请求能力。通过本篇文章,我们详细探讨了Axios的引入方式、请求方法的别名、实例的创建、async/await的使用等内容。将Axios作为模块提取,更加符合实际项目开发需求,可以有效提高代码的复用性和可维护性。
相关文章:

使用Axios函数库进行网络请求的使用指南
目录 前言1. 什么是Axios2. Axios的引入方式2.1 通过CDN直接引入2.2 在模块化项目中引入 3. 使用Axios发送请求3.1 GET请求3.2 POST请求 4. Axios请求方式别名5. 使用Axios创建实例5.1 创建Axios实例5.2 使用实例发送请求 6. 使用async/await简化异步请求6.1 获取所有文章数据6…...

Vue2+ElementUI:用计算属性实现搜索框功能
前言: 本文代码使用vue2element UI。 输入框搜索的功能,可以在前端通过计算属性过滤实现,也可以调用后端写好的接口。本文介绍的是通过计算属性对表格数据实时过滤,后附完整代码,代码中提供的是死数据,可…...

抖音热门素材去哪找?优质抖音视频素材网站推荐!
是不是和我一样,刷抖音刷到停不下来?越来越多的朋友希望在抖音上创作出爆款视频,但苦于没有好素材。今天就来推荐几个超级实用的抖音视频素材网站,让你的视频内容立刻变得高大上!这篇满是干货,直接上重点&a…...
spring-cache concurrentHashMap 自定义过期时间
1.自定义实现缓存构建工厂 import java.util.concurrent.ConcurrentHashMap; import java.util.concurrent.ConcurrentMap;import lombok.Getter; import lombok.Setter; import org.springframework.beans.factory.BeanNameAware; import org.springframework.beans.factory.…...

解析传统及深度学习目标检测方法的原理与具体应用之道
深度学习目标检测算法 常用的深度学习的目标检测算法及其原理和具体应用方法: R-CNN(Region-based Convolutional Neural Networks)系列1: 原理: 候选区域生成:R-CNN 首先使用传统的方法(如 Se…...
shell数组
文章目录 🍊自我介绍🍊shell数组概述🍊Shell数组使用方法数组的定义直接定义单元素定义 元素的获取获取单个元素获取全部元素 获取数组长度获取整个数组长度获取单个元素的长度 操作数组增加删除 关联数组 🍊 你的点赞评论就是对博…...

高斯混合模型回归(Gaussian Mixture Model Regression,GMM回归)
高斯混合模型(GMM)是一种概率模型,它假设数据是由多个高斯分布的混合组成的。在高斯混合回归中,聚类与回归被结合成一个联合模型: 聚类部分 — 使用高斯混合模型进行聚类,识别数据的不同簇。回归部分 — 对…...

【3D Slicer】的小白入门使用指南八
3D Slicer DMRI(Diffusion MRI)-扩散磁共振认识和使用 0、简介 大脑解剖 ● 白质约占大脑的 45% ● 有髓神经纤维(大约10微米轴突直径) 白质探索 朱尔斯约瑟夫德杰林(Jules Joseph Dejerine,《神经中心解剖学》(巴黎,1890-1901):基于髓磷脂染色标本的神经解剖图谱)…...

【流量分析】常见webshell流量分析
免责声明:本文仅作分享! 对于常见的webshell工具,就要知攻善防;后门脚本的执行导致webshell的连接,对于默认的脚本要了解,才能更清晰,更方便应对。 (这里仅针对部分后门代码进行流量…...

基于树莓派的边缘端 AI 目标检测、目标跟踪、姿态估计 视频分析推理 加速方案:Hailo with ultralytics YOLOv8 YOLOv11
文件大纲 加速原理硬件安装软件安装基本设置系统升级docker 方案Demo 测试目标检测姿态估计视频分析参考文献前序树莓派文章hailo加速原理 Hailo 发布的 Raspberry Pi AI kit 加速原理,有几篇文章介绍的不错 https://ubuntu.com/blog/hackers-guide-to-the-raspberry-pi-ai-ki…...
Java在算法竞赛中的常用方法
在算法竞赛中,Java以其强大的标准库和高效的性能成为了众多参赛者的首选语言。本文将详细介绍Java在算法竞赛中的常用集合、字符串处理、进制转换、大数处理以及StringBuilder的使用技巧,帮助你在竞赛中更加得心应手。 常用集合 Java的集合框架提供了多…...

Vulnhub靶场案例渗透[10]- Momentum2
文章目录 一、靶场搭建1. 靶场描述2. 下载靶机环境3. 靶场搭建 二、渗透靶场1. 确定靶机IP2. 探测靶场开放端口及对应服务3. 扫描网络目录结构4. 代码审计5. 反弹shell6. 提权 一、靶场搭建 1. 靶场描述 - Difficulty : medium - Keywords : curl, bash, code reviewThis wor…...
Spark RDD中常用聚合算子源码层面的对比分析
在 Spark RDD 中,groupByKey、reduceByKey、foldByKey 和 aggregateByKey 是常用的聚合算子,适用于按键进行数据分组和聚合。它们的实现方式各不相同,涉及底层调用的函数也有区别。以下是对这些算子在源码层面的分析,以及每个算子…...

计算机网络 (6)物理层的基本概念
前言 计算机网络物理层是OSI模型(开放式系统互联模型)中的第一层,也是七层中的最底层,它涉及到计算机网络中数据的物理传输。 一、物理层的主要任务和功能 物理层的主要任务是处理物理传输介质上的原始比特流,确保数据…...
快速上手:Docker 安装详细教程(适用于 Windows、macOS、Linux)
### 快速上手:Docker 安装详细教程(适用于 Windows、macOS、Linux) --- Docker 是一款开源容器化平台,广泛应用于开发、测试和部署。本文将为您提供分步骤的 Docker 安装教程,涵盖 Windows、macOS 和 Linux 系统。 …...
kafka消费者出现频繁Rebalance
kafka消费者在正常使用过程中,突然出现了不消费消息的情况,项目里是使用了多个消费者消费不同数据,按理不会相互影响,看日志,发现消费者出现了频繁的Rebalance。 Rebalance的触发条件 组成员发生变更(新consumer加入组…...

rk3399开发环境使用Android 10初体验蓝牙功能
版本 日期 作者 变更表述 1.0 2024/11/10 于忠军 文档创建 零. 前言 由于Bluedroid的介绍文档有限,以及对Android的一些基本的知识需要了(Android 四大组件/AIDL/Framework/Binder机制/JNI/HIDL等),加上需要掌握的语言包括Java/C/C等࿰…...

ASP.NET 部署到IIS,访问其它服务器的共享文件 密码设定
asp.net 修改上面的 IIS需要在 配置文件 添加如下内容 》》》web.config <system.web><!--<identity impersonate"true"/>--><identity impersonate"true" userName"您的账号" password"您的密码" /><co…...

将自定义函数添加到MATLAB搜索路径的方法
在MATLAB中,将自定义函数添加到搜索路径可以确保你能够方便地调用这些函数,而不必每次都指定完整路径。本文介绍几种将自定义函数添加到MATLAB搜索路径的方法 文章目录 使用 MATLAB 的路径管理工具使用 addpath 命令在启动时自动添加路径使用 genpath 命…...

云原生之运维监控实践-使用Telegraf、Prometheus与Grafana实现对InfluxDB服务的监测
背景 如果你要为应用程序构建规范或用户故事,那么务必先把应用程序每个组件的监控指标考虑进来,千万不要等到项目结束或部署之前再做这件事情。——《Prometheus监控实战》 去年写了一篇在Docker环境下部署若依微服务ruoyi-cloud项目的文章,当…...

【Python】 -- 趣味代码 - 小恐龙游戏
文章目录 文章目录 00 小恐龙游戏程序设计框架代码结构和功能游戏流程总结01 小恐龙游戏程序设计02 百度网盘地址00 小恐龙游戏程序设计框架 这段代码是一个基于 Pygame 的简易跑酷游戏的完整实现,玩家控制一个角色(龙)躲避障碍物(仙人掌和乌鸦)。以下是代码的详细介绍:…...

【配置 YOLOX 用于按目录分类的图片数据集】
现在的图标点选越来越多,如何一步解决,采用 YOLOX 目标检测模式则可以轻松解决 要在 YOLOX 中使用按目录分类的图片数据集(每个目录代表一个类别,目录下是该类别的所有图片),你需要进行以下配置步骤&#x…...
css的定位(position)详解:相对定位 绝对定位 固定定位
在 CSS 中,元素的定位通过 position 属性控制,共有 5 种定位模式:static(静态定位)、relative(相对定位)、absolute(绝对定位)、fixed(固定定位)和…...

BCS 2025|百度副总裁陈洋:智能体在安全领域的应用实践
6月5日,2025全球数字经济大会数字安全主论坛暨北京网络安全大会在国家会议中心隆重开幕。百度副总裁陈洋受邀出席,并作《智能体在安全领域的应用实践》主题演讲,分享了在智能体在安全领域的突破性实践。他指出,百度通过将安全能力…...
浅谈不同二分算法的查找情况
二分算法原理比较简单,但是实际的算法模板却有很多,这一切都源于二分查找问题中的复杂情况和二分算法的边界处理,以下是博主对一些二分算法查找的情况分析。 需要说明的是,以下二分算法都是基于有序序列为升序有序的情况…...
#Uniapp篇:chrome调试unapp适配
chrome调试设备----使用Android模拟机开发调试移动端页面 Chrome://inspect/#devices MuMu模拟器Edge浏览器:Android原生APP嵌入的H5页面元素定位 chrome://inspect/#devices uniapp单位适配 根路径下 postcss.config.js 需要装这些插件 “postcss”: “^8.5.…...
AGain DB和倍数增益的关系
我在设置一款索尼CMOS芯片时,Again增益0db变化为6DB,画面的变化只有2倍DN的增益,比如10变为20。 这与dB和线性增益的关系以及传感器处理流程有关。以下是具体原因分析: 1. dB与线性增益的换算关系 6dB对应的理论线性增益应为&…...

uniapp手机号一键登录保姆级教程(包含前端和后端)
目录 前置条件创建uniapp项目并关联uniClound云空间开启一键登录模块并开通一键登录服务编写云函数并上传部署获取手机号流程(第一种) 前端直接调用云函数获取手机号(第三种)后台调用云函数获取手机号 错误码常见问题 前置条件 手机安装有sim卡手机开启…...
Kafka主题运维全指南:从基础配置到故障处理
#作者:张桐瑞 文章目录 主题日常管理1. 修改主题分区。2. 修改主题级别参数。3. 变更副本数。4. 修改主题限速。5.主题分区迁移。6. 常见主题错误处理常见错误1:主题删除失败。常见错误2:__consumer_offsets占用太多的磁盘。 主题日常管理 …...
git: early EOF
macOS报错: Initialized empty Git repository in /usr/local/Homebrew/Library/Taps/homebrew/homebrew-core/.git/ remote: Enumerating objects: 2691797, done. remote: Counting objects: 100% (1760/1760), done. remote: Compressing objects: 100% (636/636…...