Jquery ajax, Axios, Fetch区别之我见

免费帮忙内推阿里等各大IT公司的岗位,有兴趣能够带简历加微信angeltune

引言

前端技术真是一个发展飞快的领域,我三年前入职的时候只有原生XHR和Jquery ajax,咱们还曾被JQuery 1.9版本版本如下不支持大文件请求这个问题卡了半天(最后本身写了原生的XHR请求)。一晃眼,JQuery ajax早已不能专美于前,axios和fetch都已经开始分别抢占“请求”这个前端高地。本文将会尝试着阐述他们之间的区别,并给出本身的一些理解。html

1 JQuery ajax

$.ajax({
   type: 'POST',
   url: url,
   data: data,
   dataType: dataType,
   success: function () {},
   error: function () {}
});

这个我就不用多言了把,是对原生XHR的封装,除此之外还增添了对JSONP的支持。有一说一的说一句,JQuery ajax通过多年的更新维护,真的已是很是的方便了,优势无需多言;若是是硬要举出几个缺点,那可能只有前端

  • 自己是针对MVC的编程,不符合如今前端MVVM的浪潮
  • 基于原生的XHR开发,XHR自己的架构不清晰,已经有了fetch的替代方案
  • JQuery整个项目太大,单纯使用ajax却要引入整个JQuery很是的不合理(采起个性化打包的方案又不能享受CDN服务)

尽管JQuery对咱们前端的开发工做曾有着(如今也仍然有着)深远的影响,可是咱们能够看到随着VUE,REACT新一代框架的兴起,以及ES规范的完善,更多API的更新,JQuery这种大而全的JS库,将来的路会越走越窄。node

总结:廉颇老矣,尚能饭,可是总有饭不动的一天。

2 Axios

axios({
    method: 'post',
    url: '/user/12345',
    data: {
        firstName: 'Fred',
        lastName: 'Flintstone'
    }
})
.then(function (response) {
    console.log(response);
})
.catch(function (error) {
    console.log(error);
});

Vue2.0以后,尤雨溪推荐你们用axios替换JQuery ajax,想必让Axios进入了不少人的目光中。Axios本质上也是对原生XHR的封装,只不过它是Promise的实现版本,符合最新的ES规范,从它的官网上能够看到它有如下几条特性:ios

  • 从 node.js 建立 http 请求
  • 支持 Promise API
  • 客户端支持防止CSRF
  • 提供了一些并发请求的接口(重要,方便了不少的操做)

这个支持防止CSRF其实挺好玩的,是怎么作到的呢,就是让你的每一个请求都带一个从cookie中拿到的key, 根据浏览器同源策略,假冒的网站是拿不到你cookie中得key的,这样,后台就能够轻松辨别出这个请求是不是用户在假冒网站上的误导输入,从而采起正确的策略。git

Axios既提供了并发的封装,也没有下文会提到的fetch的各类问题,并且体积也较小,当之无愧如今最应该选用的请求的方式。github

总结:谁敢横刀立马,惟我Axios将军!

3 Fetch

fetch号称是AJAX的替代品,它的好处在《传统 Ajax 已死,Fetch 永生》中提到有如下几点:ajax

  • 符合关注分离,没有将输入、输出和用事件来跟踪的状态混杂在一个对象里
  • 更好更方便的写法,诸如:
try {
  let response = await fetch(url);
  let data = response.json();
  console.log(data);
} catch(e) {
  console.log("Oops, error", e);
}

坦白说,上面的理由对我来讲彻底没有什么说服力,由于不论是Jquery仍是Axios都已经帮咱们把xhr封装的足够好,使用起来也足够方便,为何咱们还要花费大力气去学习fetch?chrome

我认为fetch的优点主要优点就是:编程

  • 更加底层,提供的API丰富(request, response)
  • 脱离了XHR,是ES规范里新的实现方式

你们都喜欢新的东西,坦白说,做为一个前端工程师,我在使用原生XHR的时候,尽管偶尔以为写的丑陋,可是在使用了JQuery和axios以后,已经对这一块彻底无所谓了。固然,若是新的fetch能作的一样好,我为了避免掉队也会选择使用fetch。这个道理其实很好理解:你有一架歼8,魔改了N次,性能达到了歼10的水准,可是要是有我的给你拿来一架新的歼10,你也会坚决果断的选择新的歼10——不只仅是新,也表明了还有新的魔改潜力。json

可是我最近在使用fetch的时候,也遇到了很多的问题:

  • fetch是一个低层次的API,你能够把它考虑成原生的XHR,因此使用起来并非那么舒服,须要进行封装

例如:

1)fetch只对网络请求报错,对400,500都当作成功的请求,须要封装去处理
2)fetch默认不会带cookie,须要添加配置项
3)fetch不支持abort,不支持超时控制,使用setTimeout及Promise.reject的实现的超时控制并不能阻止请求过程继续在后台运行,形成了流量的浪费
4)fetch没有办法原生监测请求的进度,而XHR能够

PS: fetch的具体问题你们能够参考:《fetch没有你想象的那么美》《fetch使用的常见问题及解决方法

看到这里,你内心必定有个疑问,这鬼东西就是个半拉子工程嘛,我仍是回去用Jquery或者Axios算了——其实我就是这么打算的。可是,必需要提出的是,我发现fetch在前端的应用上有一项xhr怎么也比不上的能力:跨域的处理。

咱们都知道由于同源策略的问题,浏览器的请求是可能随便跨域的——必定要有跨域头或者借助JSONP,可是,fetch中能够设置mode为"no-cors"(不跨域),以下所示:

fetch('/users.json', {
    method: 'post', 
    mode: 'no-cors',
    data: {}
}).then(function() { /* handle response */ });

这样以后咱们会获得一个type为“opaque”的返回。须要指出的是,这个请求是真正抵达事后台的,因此咱们可使用这种方法来进行信息上报,在咱们以前的image.src方法中多出了一种选择,另外,咱们在network中能够看到这个请求后台设置跨域头以后的实际返回,有助于咱们提早调试接口(固然,经过chrome插件咱们也能够作的到)。总之,fetch如今还不是很好用,我尝试过几个fetch封装的包,都还不尽如人意。

总结:酋长的孩子,还需成长

总结

若是你是直接拉到文章底部的,只须要知道如今无脑使用axios便可,Jquery老迈笨拙,fetch年轻稚嫩,只有Axios正当其年!

相关文章
相关标签/搜索