jq-ajax、axios、fetch的区别
Ajax技术最开始是只有原生XHR和jq-ajax两种方式。后来,axios和fetch出现,抢占原有方式的地盘。
一、jq-ajax
$.ajax({ type: 'POST', url: url, data: data, dataType: dataType, success: function () {}, error: function () {} });
jq-ajax是对原生XHR的封装。
优点:
1.支持JSONP
2.非常方便
缺点:
1.本身是针对MVC的编程,不符合现在前端MVVM的浪潮
2.基于原生的XHR开发,XHR本身的架构不清晰,已经有了fetch的替代方案
3.JQuery整个项目太大,单纯使用ajax却要引入整个JQuery非常的不合理
尽管JQuery对我们前端的开发工作曾有着(现在也仍然有着)深远的影响,但是我们可以看到随着VUE、REACT新一代框架的兴起以及ES规范的完善,
更多API的更新,JQuery这种大而全的JS库,未来的路会越走越窄。
总结:廉颇老矣,尚能饭,但是总有饭不动的一天。
二、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规范,从它的官网上可以看到它有以下几条特性:
- 从 node.js 创建 http 请求
- 支持 Promise API
- 客户端支持防止CSRF(跨站点请求伪造)
- 提供了一些并发请求的接口(重要,方便了很多的操作)
这个支持防止CSRF其实挺好玩的,是怎么做到的呢,就是让你的每个请求都带一个从cookie中拿到的key, 根据浏览器同源策略,假冒的网站是拿不到你cookie中得key的,这样,后台就可以轻松辨别出这个请求是否是用户在假冒网站上的误导输入,从而采取正确的策略。
Axios既提供了并发的封装,也没有下文会提到的fetch的各种问题,而且体积也较小,当之无愧现在最应该选用的请求的方式。
总结:谁敢横刀立马,唯我Axios将军!
3.fetch
fetch号称是AJAX的替代品,它的好处有以下几点:
- 符合关注分离,没有将输入、输出和用事件来跟踪的状态混杂在一个对象里
- 更好更方便的写法,诸如:
try { let response = await fetch(url); let data = response.json(); console.log(data); } catch(e) { console.log("Oops, error", e); }
fetch的优势主要优势就是:
- 更加底层,提供的API丰富(request, response)
- 脱离了XHR,是ES规范里新的实现方式
fetch是一个低层次的API,你可以把它考虑成原生的XHR,所以使用起来并不是那么舒服,需要进行封装。
总结:酋长的孩子,还需成长。
如果你是直接拉到文章底部的,只需要知道现在无脑使用axios即可,Jquery老迈笨拙,fetch年轻稚嫩,只有Axios正当其年!