一、Ajax

  • Ajax指的是XMLHttpRequest(XHR), 最早出现的发送后端请求技术,核心使用XMLHttpRequest对象,如果多个请求之间如果有先后关系的话,就会出现回调地狱。
  • JQuery ajax 是对原生XHR的封装,除此以外还增添了对JSONP的支持。经过多年的更新维护,真的已经是非常的方便了,优点无需多言

Ajax的缺点:

  1. 本身是针对MVC的编程,不符合现在前端MVVM的浪潮
  2. 基于原生的XHR开发,XHR本身的架构不清晰。
  3. JQuery整个项目太大,单纯使用ajax却要引入整个JQuery非常的不合理(采取个性化打包的方案又不能享受CDN服务)
  4. 容易出现回调地狱的问题
  5. 不符合关注分离的原则

二、axios

Vue2.0之后,尤雨溪推荐我们使用axios替换JQuery ajax。
axios 是一个基于Promise的请求库,用于浏览器和nodejs中,本质上浏览器的axios也是对原生XHR的封装,只不过它是Promise的实现版本,符合最新的ES规范,它本身具有以下特征:
1.从浏览器中创建 XMLHttpRequest
2.支持 Promise API
3.客户端支持防止CSRF
4.提供了一些并发请求的接口(重要,方便了很多的操作)
5.从node.js创建 http 请求
6.拦截请求和响应
7.转换请求和响应数据
8.取消请求
9.自动转换JSON数据

三、fetch

fetch号称是AJAX的替代品,是在ES6出现的,使用了ES6中的promise对象。Fetch是基于promise设计的,Fetch的代码结构比起ajax简单多了,参数有点像jQuery ajax。但是一定记住fetch不是ajax的进一步封装,而是原生js,没有使用XMLHttpRequest对象。
fetch的优点:
1.符合关注分离,没有将输入、输出和用事件来跟踪的状态混杂在一个对象里
2.更好更方便的写法
3.基于标准 Promise 实现,支持 async/await
4.更加底层,提供的API丰富(request, response)
5.脱离了XHR,是ES6规范里新的实现方式