axios库的核心代码解析及总结

 更新时间:2022年09月22日 11:48:06   作者:sunsetFeng  
这篇博客针对axios库的核心代码做一个简要总结,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

一、关键步骤

1.创建axios对象

axios库导出的对象是一个已经被创建好的axios对象,它本质上是一个方法,可以直接接收一个config配置参数进行请求。在库的入口处,即可看到如下代码:

function createInstance(defaultConfig) {
  // 传入默认配置生成axios对象
  const context = new Axios(defaultConfig);
  // 本质是request方法,this上下文绑定context
  const instance = bind(Axios.prototype.request, context);
  // 将Axios原型上的属性复制到instance
  utils.extend(instance, Axios.prototype, context, {allOwnKeys: true});
  // 将context上的属性复制到instance
  utils.extend(instance, context, {allOwnKeys: true});
  // 暴露create工厂方法供外部创建自定义的axios对象
  instance.create = function create(instanceConfig) {
    return createInstance(mergeConfig(defaultConfig, instanceConfig));
  };

  return instance;
}
// 默认暴露的axios对象
const axios = createInstance(defaults);

上述代码是创建默认axios对象的流程,这个对象上有Axios类的实例属性以及原型上的方法,且自身的是一个request方法,整个库最核心的也就是这个request方法。

2.请求

Axios的原型上存在很多辅助方法,如get,post,put等等,这些方法最终都会调用request方法,且默认设置了请求参数中的method属性,仅仅是一种封装的快捷调用方式。所以直接使用axios方法(axios的本质是一个方法),传入一个合法参数和使用axios.get等方法进行请求没有区别

二、Axios类

1.基础属性

axios类型的对象,存在2个基础属性

  • defaults:默认的请求参数
  • interceptors:请求和响应的拦截器

2.辅助方法

axios类型的对象存在很多辅助方法,如下:

  • delete
  • get
  • head
  • options
  • post
  • put
  • patch
  • postForm
  • patchForm
  • putForm

这些方法本质上都是request的封装,调用这些方法时,都会调用request方法,但相应的会预设置部分请求参数,如method和headers

3.request方法

这个方法是整个库的核心,它接收一个配置作为参数。内部流程如下:

  • (1)参数合并

axios对象在创建时,会传入一个默认请求配置对象,这个对象会和请求时传入的请求配置对象进行合并。

  • (2)处理headers

合并后的对象需要进一步处理headers,一些headers配置只针对特定类型的请求,如get类型。

  • (3)运行执行队列

这一步是整个request设计的较为精妙的地方。执行队列有2种执行模式,同步模式和异步模式,默认为异步模式。分别如下:

  • 异步模式

  • 同步模式

简单来说,就是request拦截器,request请求,response拦截器一起组成了一个执行队列。在异步模式下,队列里面每一个执行方法执行完成之后,会继续调用下一个执行方法。同步模式下,request拦截器和request请求会按顺序同步执行,但response拦截器会在请求返回后异步执行

三、adpter适配器

Axios库是跨平台的,可以在node环境和web环境同时使用。因此内部有个"适配器"的概念,adpter是一个方法,一个请求本质上就是调用这个方法,方法必须返回一个Promise对象。请求配置中,甚至可以让我们自己去实现自己的适配器。

// `adapter` 允许自定义处理请求,这使测试更加容易。 // 返回一个 promise 并提供一个有效的响应 (参见 lib/adapters/README.md)。

adapter: function (config) { /* ... */ },

如果提供了这么一个参数,那么将不会采用默认的适配器,一般供测试使用。

1.xhradpter

xhradpter适配器适用于web环境,利用XMLHttpRequest对象实现。本质上就是在操作一个XMLHttpRequest对象。

2.httpadpter

httpadpter适配器适用于node环境,利用node原生的http模块实现。

以上就是axios库的核心代码解析及总结的详细内容,更多关于axios库核心代码的资料请关注脚本之家其它相关文章!

相关文章

  • Vue实现半自动打字机特效

    Vue实现半自动打字机特效

    本文主要介绍了Vue实现半自动打字机特效,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-12-12
  • vue3.0路由自动导入的方法实例

    vue3.0路由自动导入的方法实例

    这篇文章主要给大家介绍了关于vue3.0路由自动导入的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-04-04
  • VUE 使用canvas绘制管线管廊示例详解

    VUE 使用canvas绘制管线管廊示例详解

    这篇文章主要为大家介绍了VUE 使用canvas绘制管线/管廊实现示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • vue关于下载文件常用的几种方式

    vue关于下载文件常用的几种方式

    这篇文章主要介绍了vue关于下载文件常用的几种方式,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-10-10
  • vue与原生app的对接交互的方法(混合开发)

    vue与原生app的对接交互的方法(混合开发)

    vue开发h5项目特别是移动端的项目,很多都是打包后挂载在原生APP上的,这篇文章主要介绍了vue与原生app的对接交互的方法,非常具有实用价值,需要的朋友可以参考下
    2018-11-11
  • vue的状态更新方式(异步更新解决)

    vue的状态更新方式(异步更新解决)

    这篇文章主要介绍了vue的状态更新方式(异步更新解决),具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-04-04
  • Vue实现商品详情页的评价列表功能

    Vue实现商品详情页的评价列表功能

    这篇文章主要介绍了Vue实现商品详情页的评价列表功能,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-09-09
  • Vue3使用el-form嵌套el-table进行单条数据的表单校验功能

    Vue3使用el-form嵌套el-table进行单条数据的表单校验功能

    在实际开发过程中,我们经常需要处理表格中的表单数据,比如在编辑表格中的某一行数据时进行校验,本文给大家介绍了Vue3使用el-form嵌套el-table进行单条数据的表单校验功能,文中有相关的代码供大家参考,需要的朋友可以参考下
    2024-08-08
  • 在vue项目中使用Nprogress.js进度条的方法

    在vue项目中使用Nprogress.js进度条的方法

    NProgress.js是轻量级的进度条组件,使用简便,可以很方便集成到单页面应用中。这篇文章主要介绍了在vue项目中使用Nprogress.js进度条的方法,需要的朋友可以参考下
    2018-01-01
  • vue中elementUI里面一些插件的使用

    vue中elementUI里面一些插件的使用

    Element UI是一套基于Vue的桌面端组件库,封装好了很多常用的UI组件,下面这篇文章主要给大家介绍了关于vue中elementUI里面一些插件的使用方法,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
    2022-06-06

最新评论