axios中的创建请求方式很多,比如axios(url),axios.get(url),axios.post(url),axios.delete(url),方便快捷的api设计让axios火得一塌糊涂。

先列一下所有请求方法,代码如下:

1. axios(config) || axios(url[, config])

2. axios.request(config)(实际上axios.request(url)和axios.request(url[, config])也是可以运行的,其d.ts可能写得有点问题,会给错误提示,因此暂时不考虑)

3. axios.get(url[, config])

4. axios.head(url[, config])

5. axios.options(url[, config])

6. axios.post(url[, data[, config]])

7. axios.put(url[, data[, config]])

8. axios.patch(url[, data[, config]])

9. axios.postForm(url[, data[, config]])

10. axios.putForm(url[, data[, config]])

11. axios.patchForm(url[, data[, config]])

其中9、10、11是新特性,文档中也没有说明,
其实就是在headers中多加上'Content-Type': 'multipart/form-data'。
这个有个问题就是axios.post在config.data传递参数时,会被忽略掉,
而是直接拿第二个参数data,axios.post(url, null, {data: FormData})这样写也是有可能的,特别是对于记不清楚api的我来说,所以建议作者大大从data: data 改成 data: data || config.data。
emm,完美~

先下结论,无论使用任何请求方法,最终都是调用Axios.prototype.request这个方法。

Axios构造函数的核心代码如下:

/* axios/lib/core/Axios.js */
// Axios构造函数
function Axios(defaultConfig) {
this.defaults = defaultConfig;
this.interceptors = {
request: new InterceptorManager(),
response: new InterceptorManager()
}
} // Axios原型上的request方法
Axios.prototype.request = function(configOrUrl, config) {
... ... ...
} // Axios原型上的['delete', 'get', 'head', 'options']四种方法
utils.forEach(['delete', 'get', 'head', 'options'], function(method) {
Axios.prototype[method] = function(url, config) {
return this.request(mergeConfig(config || {}, {
method: method,
url: url,
data: (config || {}).data
}));
}
}); // Axios原型上的['post', 'put', 'patch']三种方法
utils.forEach(['post', 'put', 'patch'], function(method) {
Axios.prototype[method] = function(url, data, config) {
function generateHTTPMethod(isForm) {
return function httpMethod(url, data, config) {
return this.request(mergeConfig(config || {}, {
method: method,
headers: isForm ? {
'Content-Type': 'multipart/form-data'
} : {},
url: url,
data: data
}));
};
} Axios.prototype[method] = generateHTTPMethod(); Axios.prototype[method + 'Form'] = generateHTTPMethod(true);
}
}); /* axios/lib/utils.js */
// forEach函数
function forEach(obj, fn) {
if (obj === null || typeof obj === undefined) {
return;
} if (typeof obj !== 'object') {
obj = [obj];
} if (Array.isArray(obj)) {
for (var i = 0; i < obj.length; i++) {
fn.call(null, obj[i], i, obj);
}
} else {
for (var key in obj) {
if (Object.prototype.hasOwnProperty.call(obj, key)) {
fn.call(null, obj[key], key, obj);
}
}
}
}

作者大大用了forEach这个方法,巧妙的写了Axios.prototype.get、Axios.prototype.post等原型方法,那么axios()为什么能触发?axios为什么会有get、post等属性且axios.get()也能触发呢?代码如下:

/* axios/lib/axios.js */
function createInstance(defaultConfig) {
// 生成实例对象
var context = new Axios(defaultConfig); // 通过bind方法让instance等同于Axios.prototype.request,且执行时的this指向当前的实例对象
var instance = bind(Axios.prototype.request, context); // 将Axios.prototype原型上的方法作为instance的属性, 且方法中的this指向当前的实例对象
utils.extend(instance, Axios.request, context); // 将该实例对象的defaults、interceptors属性作为instance的属性
utils.extend(instance, context); instace.cteate = function (instanceConfig) {
// 合并属性,因此新的实例也拥有默认实例设置过的属性
return createInstance(mergeConfig(defaultConfig, instanceConfig));
} // 返回实例对象
return instance;
} // import axios from 'axios'中axios便是这个变量
var axios = createInstance(defaultConfig); /* axios/lib/utils.js */
// 从上述代码中,发现bind和extends起到的作用非常关键
// bind函数
function bind(fn, thisArg) {
return function wrap() {
var args = new Array(arguments.length);
for (var i = 0l i < arguments.length; i++) {
args[i] = arguments[i];
}
fn.apply(thisArg, args);
}
} // extends函数
function extend(a, b, thisArg) {
forEach(b, function assignValue(val, key) {
if (thisArg && typeof val === 'function') {
a[key] = bind(val, thisArg);
} else {
a[key] = val;
}
});
return a;
}

最后附上axios官方文档:https://axios-http.com/

axios源码解析 - 请求方法的别名实现的更多相关文章

  1. axios源码解析 - 请求拦截器

    axios请求拦截器,也就是在请求发送之前执行自定义的函数. axios源码版本 - ^0.27.2 (源码是精简版) 平时在业务中会这样去写请求拦截器,代码如下: // 创建一个新的实例 var s ...

  2. axios 源码解析(中) 代码结构

    axios现在最新的版本的是v0.19.0,本节我们来分析一下它的实现源码,首先通过 gitHub地址获取到它的源代码,地址:https://github.com/axios/axios/tree/v ...

  3. Spring5源码解析2-register方法注册配置类

    接上回已经讲完了this()方法,现在来看register(annotatedClasses);方法. // new AnnotationConfigApplicationContext(AppCon ...

  4. Serilog源码解析——使用方法

    在上两篇文章(链接1和链接2)中,我们通过一个简易 demo 了解到了一个简单的日志记录类库所需要的功能,即一条日志有哪些数据,以及如何通过一次记录的方式将同一条日志消息记录到多个日志媒介中.在本文中 ...

  5. Spring5源码解析3-refresh方法初探

    接上回分析完register(annotatedClasses);后,现在来看一下refresh();方法. // new AnnotationConfigApplicationContext(App ...

  6. Spring5源码解析4-refresh方法之invokeBeanFactoryPostProcessors

    invokeBeanFactoryPostProcessors(beanFactory);方法源码如下: protected void invokeBeanFactoryPostProcessors( ...

  7. axios 源码解析(下) 拦截器的详解

    axios的除了初始化配置外,其它有用的应该就是拦截器了,拦截器分为请求拦截器和响应拦截器两种: 请求拦截器    ;在请求发送前进行一些操作,例如在每个请求体里加上token,统一做了处理如果以后要 ...

  8. 从源码解析LinkedList集合

         上篇文章我们介绍了ArrayList类的基本的使用及其内部的一些方法的实现原理,但是这种集合类型虽然可以随机访问数据,但是如果需要删除中间的元素就需要移动一半的元素的位置,效率低下.并且它内 ...

  9. spring boot @Value源码解析

    Spring boot 的@Value只能用于bean中,在bean的实例化时,会给@Value的属性赋值:如下面的例子: @SpringBootApplication @Slf4j public c ...

随机推荐

  1. 解释基于 XML Schema 方式的切面实现?

    在这种情况下,切面由常规类以及基于 XML 的配置实现.

  2. 学习ELK日志平台(三)

    ELK(elasticsearch.logstash.kibana) Elastic Stack是原ELK Stack在5.0版本加入Beats套件后的新称呼 解决痛点: 开发人员不能登录线上serv ...

  3. Python学习--Python的了解与安装

    Python简介: Python 是一种解释型.面向对象.动态数据类型的高级程序设计语言. Python 由荷兰人Guido van Rossum 于 1989 年底发明,第一个公开发行版发行于 19 ...

  4. leetcode_9回文数

    给你一个整数 x ,如果 x 是一个回文整数,返回 true :否则,返回 false . 回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数. 例如,121 是回文,而 123 不是. 来 ...

  5. docker 容器简单使用

    文章目录 docker简介 docker容器简单使用 1.HelloWorld 2.运行交互式的容器 3.启动容器(后台模式) 安装docker容器的博文有很多这里就不做过多赘述了,另外如果不想安装d ...

  6. 7_线性控制器设计(Linear Controller Design)

    开环系统中 状态方程,其中A的特征值将决定这个系统的表现(稳定性或者收敛速度:特征值小于0时系统稳定) 如果开环系统特征值大于0时(即系统不稳定时): 可以引入输入量U时(U是关于状态变量X的函数), ...

  7. android:text 文字阴影设置

    <SPAN style="FONT-SIZE: 16px"><TextView  android:id="@+id/text"       a ...

  8. 用Python爬取斗鱼网站的一个小案例

    思路解析: 1.我们需要明确爬取数据的目的:为了按热度查看主播的在线观看人数 2.浏览网页源代码,查看我们需要的数据的定位标签 3.在代码中发送一个http请求,获取到网页返回的html(需要注意的是 ...

  9. python 简要小结

    初学python 简单总结部分内置函数 将两个数组合并为元组:zip()   解压:zip(*zip) range(a,b,c) 取值范围 起始:a   结尾:b   间隔:c   (参数不能为空否则 ...

  10. 虚拟机上 安装 CentoOS 7.5 1804 过程记录

    1.准备安装镜像 在开始安装CentOS之前,必须下载安装ISO映像.镜像可从CentOS网站https://www.centos.org/download/.提供以下基本类型的镜像: DVD ISO ...