一.axios介绍
.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.从浏览器中创建 XMLHttpRequest
2.支持 Promise API
3.客户端支持防止CSRF
4.提供了一些并发请求的接口(重要,方便了很多的操作)
5.从 node.js 创建 http 请求
6.拦截请求和响应
7.转换请求和响应数据
8.取消请求
9.自动转换JSON数据
PS:防止CSRF:就是让你的每个请求都带一个从cookie中拿到的key, 根据浏览器同源策略,假冒的网站是拿不到你cookie中得key的,这样,后台就可以轻松辨别出这个请求是否是用户在假冒网站上的误导输入,从而采取正确的策略。
get请求与post请求的区别
1.post请求要比get请求更安全
2.post请求比get请求慢,原因: post请求会向服务器发送确认请求,服务器确认后才开始发送数据,get请求会直接向服务发送数据,直到服务器返回确认才停止
3.post发送大数据
4.get在浏览器回退是是无害的,post会在次提交请求
5.get请求url地址会被标识
二.ajax介绍
1.异步javascrip和xml(html)的英文缩写
2.可以在不重新加载网页的情况下,局部更新网页的内容的技术
3.可以跟后台使用少量的数据交换实现网页的局部更新
三.原生ajax请求步骤
1.创建异步对象(使用构造函数)
var ajax = new XMLHttpRequest();
2.设置请求的url参数,可动态传递参数到服务端
3.发送请求
4.监听事件监听数据什么时候回来
四,关于fetch
1.号称是ajax的替代品,ES6中出现的,使用了ES6中出现的promise对象(在解决回调地狱问题时使用过)
2.fetch是原生js不是对ajax的进一步封装,没有使用XML HttpReques对象
优势
1. 语法简洁,更加语义化
2. 基于标准 Promise 实现,支持 async/await
3. 同构方便,使用 [isomorphic-fetch](https://github.com/matthew-andrews/isomorphic-fetch)
4.更加底层,提供的API丰富(request, response)
5.脱离了XHR,是ES规范里新的实现方式
五,关于jQuery ajax
传统 Ajax 指的是 XMLHttpRequest(XHR), 最早出现的发送后端请求技术,隶属于原始js中,核心使用XMLHttpRequest对象,多个请求之间如果有先后关系的话,就会出现回调地狱。
JQuery ajax 是对原生XHR的封装
总结
1.传统Ajax 指的是 XMLHttpRequest(XHR),
2.axios和jQuer ajax都是对Ajax的封装
3.fetch是原生js在ES6中出现的,使用了promise对象,号称是Ajax的替代品