千家信息网

如何使用Axios

发表于:2025-02-24 作者:千家信息网编辑
千家信息网最后更新 2025年02月24日,本篇内容介绍了"如何使用Axios"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、灵魂四连问1.1
千家信息网最后更新 2025年02月24日如何使用Axios

本篇内容介绍了"如何使用Axios"的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

一、灵魂四连问

1.1 为什么要读源代码

1.2 如何选择项目

1.3 如何阅读源码

1.4 有实际的案例么

二、如何品读 Axios?

2.1 走进 Axios

Axios 是一个基于 Promise 的 HTTP 客户端,同时支持浏览器和 Node.js 环境。它是一个优秀的 HTTP 客户端,被广泛地应用在大量的 Web 项目中。

由上图可知,Axios 项目的 Star 数为 「78.1K」,Fork 数也高达 「7.3K」,是一个很优秀的开源项目,所以值得大家细细品读。

2.2 发现 Axios 的美

在确认 Axios 为 "追求目标" 之后,下一步我们就需要来发现它身上的优点(特性):

每个人对 "美" 都有不同的看法,对于阿宝哥来说,我看中了图中已选中的三点。因此,它们也很光荣地成为读源码的三个切入点。当然切入点也不是越多越好,可以先找自己最感兴趣的地方作为切入点。需要注意的是,如果切入点之间有关联关系的话,建议做个简单的排序。

2.3 感受 Axios 的美

选择切入点之后,我们就可以开始逐一感受 Axios 的设计之美。以 「能够拦截请求与响应」 这个切入点为例,首先我们就会接触到 「拦截器」 的概念。所以我们需要先了解拦截器是什么、拦截器有什么作用以及如何使用拦截器,这里我们可以从项目的 「官方文档」或者项目中的 「README.md」 文档入手。

2.3.1 拦截器的作用

Axios 提供了请求拦截器和响应拦截器来分别处理请求和响应,它们的作用如下:

  • 请求拦截器:该类拦截器的作用是在请求发送前统一执行某些操作,比如在请求头中添加 token 字段。

  • 响应拦截器:该类拦截器的作用是在接收到服务器响应后统一执行某些操作,比如发现响应状态码为 401 时,自动跳转到登录页。

2.3.2 拦截器的使用

// 添加请求拦截器 —— 处理请求配置对象 axios.interceptors.request.use(function (config) {   config.headers.token = 'added by interceptor';   return config; });  // 添加响应拦截器 —— 处理响应对象 axios.interceptors.response.use(function (data) {   data.data = data.data + ' - modified by interceptor';   return data; });  axios({   url: '/hello',   method: 'get', }).then(res =>{   console.log('axios res.data: ', res.data) });

在了解完拦截器的作用和用法之后,我们就会把焦点聚焦到 「axios」 对象,因为注册拦截器和发送请求都与它有紧密的联系。不过在看具体源码之前,阿宝哥建议先对功能点做一下梳理。以下是阿宝哥的分析思路:

Axios 的作用是用于发送 HTTP 请求,请求拦截器和响应拦截器分别对应于 HTTP 请求的不同阶段,它们的本质是一个实现特定功能的函数。这时我们就可以按照功能把发送 HTTP 请求拆解成不同类型的子任务,比如有 「用于处理请求配置对象的子任务」,「用于发送 HTTP 请求的子任务」 和 「用于处理响应对象的子任务」。当我们按照指定的顺序来执行这些子任务时,就可以完成一次完整的 HTTP 请求。

既然已经提到了任务,我们就会联想到任务管理系统的基本功能:任务注册、任务编排(优先级排序)和任务调度等。因此我们就可以考虑从 「任务注册、任务编排和任务调度」 三个方面来分析 Axios 拦截器的实现。

2.3.3 任务注册

// 添加请求拦截器 —— 处理请求配置对象 axios.interceptors.request.use(function (config) {   config.headers.token = 'added by interceptor';   return config; });  // 添加响应拦截器 —— 处理响应对象 axios.interceptors.response.use(function (data) {   data.data = data.data + ' - modified by interceptor';   return data; });

在 lib/axios.js 路径下,我们可以找到 「axios」 对象的定义。为了能直观地了解对象之间的关系,阿宝哥建议大家在读源码的过程中,多动手画画图。比如阿宝哥使用下图来总结一下 Axios 对象与 InterceptorManager 对象的内部结构与关系:

2.3.4 任务编排

现在我们已经知道如何注册拦截器任务,但仅仅注册任务是不够,我们还需要对已注册的任务进行编排,这样才能确保任务的执行顺序。

同样对于任务编排,也可以使用图的形式来展现任务编排后的结果。「这里有一个小技巧,就是可以采用对比的形式来展示任务编排后的结果,这样子会更加清楚任务编排的处理逻辑。」

2.3.5 任务调度

任务编排完成后,要发起 HTTP 请求,我们还需要按编排后的顺序执行任务调度。

需要注意的是:在阅读源码过程中,不要太在意细节。比如在研究 Axios 拦截器原理时,不需要再深入了解 「dispatchRequest」 背后的具体实现,只需知道该方法用于实现发送 HTTP 请求即可,这样才不会把整个线路拉得太长。

在分析完特定的功能点之后,也许你已经读懂的具体的源代码。但阿宝哥觉得这并不是最重要的,「更重要的是思考它的设计思想,这样设计有什么好处,对于我们有没有什么值得借鉴和学习的地方」。比如参考 Axios 拦截器的设计模型,我们就可以抽出以下通用的任务处理模型:

上面阿宝哥以 Axios 的拦截器为例,分享了读 Axios 源码的思路与技巧。接下来阿宝哥来分享一些读源码的建议和辅助工具。

三、读源码的建议

四、读源码辅助工具

如果你对下列辅助工具感兴趣的话,可以通过以下图片来源的链接,来直接打开每个工具的在线地址。

(图片来源:https://www.processon.com/view/link/5f6d2beff346fb166d0ac4fd)

五、总结

其实除了上面的内容之外,读优秀开源项目还有挺多值得关注的地方。阿宝哥在学习 BetterScroll 项目源码时,总结了一张思维导图:

(图片来源:https://www.processon.com/view/link/5f6d2beff346fb166d0ac4fd)

下面阿宝哥用一张图来总结一下 axios 和 better-scroll 这两个开源项目的学习路线:

1、Axios 项目的切入点是从 Github 中的功能特性中筛选出来的;

2、BetterScroll 的切入点是从掘金上 "BetterScroll 2.0 发布:精益求精,与你同行" 这篇文章中介绍的功能亮点中找到的。

除此之外,阿宝哥也来简单总结一下本文介绍的读源码的思路与技巧:

  • 站在巨人的肩膀,提前阅读一些项目相关的优质文章;

  • 汇总学习或工作中遇到的问题,带着问题进行源码学习;

  • 明确阅读源码的主线或切入点;

  • 尽可能从简单的示例出发来分析每个功能点;

  • 先梳理清楚主要流程,不要太在意细节,避免把整个线路拉得太长;

  • 在阅读源码过程中,要多多画图,这样理解起来会更加直观。

"如何使用Axios"的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注网站,小编将为大家输出更多高质量的实用文章!

任务 拦截器 源码 对象 项目 阿宝 切入点 功能 处理 作用 学习 建议 工具 过程 分析 设计 调度 不同 优秀 内容 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 剑灵网通哪个服务器人多 思科网络技术课程 单台服务器并发 sql数据库是什么结构 软件开发属于电子与智能化范围吗 软件开发术语表 邢台哪里有软件开发费用 狮子王下载软件开发 合肥网络技术专业学院 宁波海曙区财务软件开发地址 保监会 网络安全 通知 软件开发的总体设计怎么写 软件开发工具什么意思 青少年日网络安全意识 浦东新区综合软件开发执行标准 数据结构与数据库技术的区别 3d建模软件开发公司 往服务器装数据库怎么那么慢 延庆区信息化软件开发创新服务 广州软件开发上市公司 魔兽世界掉落数据库tbc SCIE是全文型数据库吗 浙江新一代网络技术分类服务标准 泉州企业财务软件开发 java 显示数据库表 图数据库neo4j 阳泉商场大屏导航软件开发公司 思科网络安全证书有哪些证 舟山云软件开发工程师 数据结构与数据库技术的区别
0