1.jQuery ajax
$.ajax({ type: 'POST', url: url, data: data, dataType: dataType, success: function () {}, error: function () {} });
传统Ajax指的是XMLHttpRequest(XHR),最早出现的发送后端请求技术,隶属于原始js中,核心使用XMLHttpRequest对象,多个请求之间如果有先后关系的话,就会出现回调地域。
jQuery ajax 是对原生XHR的封装,除此之外还增加了对jsonp的支持。
缺点:
1、本身是针对MVC的编程,不符合现在的前端MVVM的浪潮。
2、基于原生的XHR开发,XHR本身的架构不清晰
3、jQuery整个项目太大,单纯使用ajax却要引入整个jQuery非常的不合理(采取个性化打包的方案又不能享受CDN服务)
4、不符合关注分类的原则
5、配置和调用方式非常混乱,而且基于时间的异步模型不友好。
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是一个基于promise用于浏览器和nodejs的HTTP客户端,本质上也是对原生XHR的封装,只不过它是promise的实现版本,符合最新的ES规范,它本身具有以下特征:
1、从浏览器中创建XMLHttpRequerst
2、支持promise API
3、客户端支持防止CSRF(防止CSRF:就是让你的每个请求都带一个从cookie中拿到的key, 根据浏览器同源策略,假冒的网站是拿不到你cookie中得key的,这样,后台就可以轻松辨别出这个请求是否是用户在假冒网站上的误导输入,从而采取正确的策略。)
4、提供了一些并发请求的接口(重要,方便了很多的操作)
5、从 nodejs 创建 http 请求
6、拦截请求和响应
7、转换请求和响应数据
8、取消请求
9、自动转换json数据
3.fetch
fetch('/getList') .then(res => res.json()) .then(res => { console.log(res) })
fetch号称是ajax的替代品,是es6出现的,使用了es6中的promise对象。fetch是基于promis设计的。fetch的代码结构比起ajax简单,参数有点像jQuery ajax。但是,一定记住fetch不是ajax的进一步封装,而是原生js,没有使用XHR对象。
fetch的优点:
1.符合关注分离,没有将输入、输出和用事件来跟踪的状态混杂在一个对象里
2.更好更方便的写法
总结:axios既提供了并发的封装,也没有fetch的各种问题,而且体积也较小,当之无愧现在最应该选用的请求的方式。