Axios 的原理

news/2025/2/9 10:32:35/

在这里插入图片描述

🤍 前端开发工程师、技术日更博主、已过CET6
🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1
🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》
🍚 蓝桥云课签约作者、上架课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入门到实战全面掌握 uni-app》
💬 前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。

Axios 是一个基于 Promise 的 HTTP 客户端,用于浏览器和 Node.js。它提供了一种简单而强大的方式来发送 HTTP 请求。本文将深入探讨 Axios 的原理,帮助开发者更好地理解和使用这一库。

1. Axios 的基本使用

Axios 的基本用法非常简单。以下是一个发送 GET 请求的示例:

javascript">axios.get('/user?ID=12345').then(function (response) {console.log(response);}).catch(function (error) {console.log(error);});

我们也可以使用 async/await 语法来简化异步代码:

javascript">async function getUser() {try {const response = await axios.get('/user?ID=12345');console.log(response);} catch (error) {console.log(error);}
}

2. Axios 的核心原理

Axios 的核心原理主要包括以下几个方面:

2.1 创建 XMLHttpRequest 对象

Axios 使用原生的 XMLHttpRequest 对象来发送 HTTP 请求。在浏览器环境中,XMLHttpRequest 是一个用于与服务器交互的 API。

2.2 处理 Promise

Axios 返回一个 Promise 对象,这使得我们可以使用 thencatch 方法来处理异步操作。当请求成功时,Promise 被解析(resolved);当请求失败时,Promise 被拒绝(rejected)。

2.3 请求和响应拦截器

Axios 提供了请求和响应拦截器,允许我们在请求发送前和响应返回后执行自定义逻辑。这对于处理公共逻辑(如添加请求头、处理错误等)非常有用。

javascript">// 添加请求拦截器
axios.interceptors.request.use(function (config) {// 在发送请求之前做些什么return config;}, function (error) {// 对请求错误做些什么return Promise.reject(error);});// 添加响应拦截器
axios.interceptors.response.use(function (response) {// 对响应数据做点什么return response;}, function (error) {// 对响应错误做点什么return Promise.reject(error);});

2.4 处理请求和响应数据

Axios 允许我们通过配置对象来处理请求和响应数据。例如,我们可以设置请求头、请求方法、请求参数等。

javascript">axios({method: 'post',url: '/login',data: {firstName: 'Frodo',lastName: 'Baggins'},transformRequest: [function (data, headers) {// 对发送的数据进行转换return JSON.stringify(data);}],transformResponse: [function (data) {// 对返回的数据进行转换return JSON.parse(data);}]
});

3. Axios 的模块化设计

Axios 采用模块化设计,将不同的功能划分为不同的模块。例如,dispatchRequest 模块负责发送请求,interceptors 模块负责处理拦截器,helpers 模块提供了一些辅助函数。

这种模块化设计使得 Axios 的代码结构清晰,易于维护和扩展。

4. 总结

Axios 是一个功能强大且易于使用的 HTTP 客户端。通过深入理解 Axios 的原理,开发者可以更好地利用这一库,满足复杂的业务需求。希望本文对你有所帮助,如果你有任何问题或建议,欢迎在评论区留言讨论。


http://www.ppmy.cn/news/1570558.html

相关文章

【开源AI】AI一页一页读PDF

【开源AI】AI一页一页读PDF 可以在这里看 : 让AI 处理 PDF 文件,提取其中的知识点,并生成总结。 只是无法修改,后续若有更新在csdn这里。 【OpenAI】 API 更新: JSON 结构化输出约束机制( JSON Schema) 的一次实战。知识库的JSON Schema形式 每一页都要总结,总结的知识…

使用libcurl获取网页内容不完整的另一种情况

写一个使用libcurl获取网页的测试程序,发现获取的网页内容使用cout显示总是不完整,内容从中间截断了。 到网络上查找,也总是对不上号,不是自己想要的答案。 后来发现,写文件的方式,获取的网页文件是完整&am…

react 19 useOptimistic 竞争更新乐观值时阻塞

react 19 刚刚出,我在官网上调试这个 useOptimistic api 时,发现了一个竞争调用时的阻塞状态。当连续多次调用 updateFn 参数,且每次更新时间较长时,乐观状态的更新被阻塞了。 前往官网 useOptimistic 一节,修改末尾 …

Python----Python高级(并发编程:进程Process,多进程,进程间通信,进程同步,进程池)

一、进程Process 拥有自己独立的堆和栈,既不共享堆,也不共享栈,进程由操作系统调度;进程切换需要的资源很最大,效率低。 对于操作系统来说,一个任务就是一个进程(Process)&#xff…

4.3 线性回归的改进-岭回归/4.4分类算法-逻辑回归与二分类/ 4.5 模型保存和加载

4.3.1 带有L2正则化的线性回归-岭回归 岭回归,其实也是一种线性回归,只不过在算法建立回归方程的时候1,加上正则化的限制,从而达到解决过拟合的效果 4.3.1.1 API 4.3.1.2 观察正则化程度的变化,对结果的影响 正则化力…

【Ubuntu】本地部署Deep Seek(深度求索)大模型的保姆级教程 | 详细教程

杭州深度求索人工智能基础技术研究有限公司(简称“深度求索”或“DeepSeek”),成立于2023年,DeepSeek是一家专注通用人工智能(AGI)的中国科技公司,主攻大模型研发与应用,经营范围包括技术服务、技术开发、软…

初始JavaEE篇 —— Spring Web MVC入门(下)

找往期文章包括但不限于本期文章中不懂的知识点: 个人主页:我要学编程程(ಥ_ಥ)-CSDN博客 所属专栏:JavaEE 初始JavaEE篇 —— Spring Web MVC入门(上) 在上篇文章中,我们学习了一些注解的使用、Postman模…

Android原生开发问题汇总

Fragment顶部出现一个白条怎么办?父类布局搞事情。 layer-list被拉伸问题 Android之 ImageView android:src和tools:src的区别是什么? Android运行时权限的总结,以及EasyPermissions框架的使用 Android Studio添加EasyPemissions Android中module怎…