ajax、axios、fetch之间的区别与联系

AJAX

====

https://www.w3school.com.cn/ajax/index.asp

AJAX(Asynchronous JavaScript and XML)(异步的 JavaScript 和 XML)。AJAX不是新的编程语言,而是一种使用现有标准的新方法。**AJAX 是一种在无需重新加载整个网页的情况下,**通过后台与服务器进行少量数据交换,**能够异步更新部分网页的技术。**传统的网页(不使用 AJAX)如果需要更新内容,必需重载整个网页面。XMLHttpRequest 是 AJAX 的基础。

var xmlhttp;

if (window.XMLHttpRequest) {

// code for IE7+, Firefox, Chrome, Opera, Safari

xmlhttp = new XMLHttpRequest();

} else {

// code for IE6, IE5

xmlhttp = new ActiveXObject(“Microsoft.XMLHTTP”);

}

xmlhttp.open(“POST”, ‘http://xxx’, true);

// 如果需要像 HTML 表单那样 POST 数据,使用 setRequestHeader() 来添加 HTTP 头。然后在 send() 方法中规定您希望发送的数据

xmlhttp.setRequestHeader(“Content-type”, “application/x-www-form-urlencoded”);

xmlhttp.send(“name=小王&age=18”);

xmlhttp.onreadystatechange = function() {

if (xmlhttp.readyState == 4 && xmlhttp.status == 200) {

document.getElementById(“myDiv”).innerHTML = xmlhttp.responseText;

} else {

console.error(“请求错误”);

}

}

jQuery ajax

===========

jQuery是一个快速的,简洁的javaScript库,使用户能更方便地处理HTML documents、events、实现动画效果,并且方便地为网站提供AJAX交互。这里的 ajax 是jQuery库里面封装好的函数,是对原生XHR的封装,除此以外还增添了对JSONP的支持。

$.ajax({

type: ‘POST’,

url: ‘http://xxx’,

data: {

name: ‘小王’,

age: ‘18’

},

success: function () {},

error: function () {}

});

优缺点:

  • 本身是针对MVC的编程,不符合现在前端MVVM的浪潮

  • 基于原生的XHR开发,XHR本身的架构不清晰,已经有了fetch的替代方案

  • JQuery整个项目太大,单纯使用ajax却要引入整个JQuery非常的不合理(采取个性化打包的方案又不能享受CDN服务)

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

axios

=====

axios 是一个基于Promise 用于浏览器和 nodejs 的 HTTP 客户端

axios({

method: ‘post’,

url: url,

data: {

name: ‘小王’,

age: ‘18’

}

})

.then(function (response) {

console.log(response);

})

.catch(function (error) {

console.log(error);

});

Vue2.0之后,推荐大家用axios替换JQuery ajax,让Axios进入了很多人的目光中。Axios本质上也是对原生XHR的封装,只不过它是Promise的实现版本,符合最新的ES规范

  • 从浏览器中创建 XMLHttpRequest

  • 从 node.js 发出 http 请求

  • 支持 Promise API

  • 拦截请求和响应

  • 转换请求和响应数据

  • 取消请求

  • 自动转换JSON数据

  • 客户端支持防止CSRF/XSRF

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

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

fetch

=====

fetch号称是AJAX的替代品,可以参考《传统 Ajax 已死,Fetch 永生

  • 符合关注分离,没有将输入、输出和用事件来跟踪的状态混杂在一个对象里

  • 更好更方便的写法

try {

let response = await fetch(url);

let data = response.json();

console.log(data);

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值