axios
1.是一个常用的http库,可用于浏览器和nodejs的客户端;
2.同时处理并发请求;
3.拦截器(请求拦截器interceptors.request、响应拦截器interceptors.response)
请求拦截器interceptors.request是指可以拦截住每次或指定的http请求,并可修改配置项
响应拦截器interceptors.response 是指每次http请求后截住每次或指定http请求,并可修改返回结果项
4.浏览器支持防止csrf(跨站请求伪造)
5.数据修改器
请求转换器 transformRequest 指在请求之前对数据进行转换
响应转换器 transformResponse 主要对请求响应后的响应体做数据转换
6.可以通过config中的cancelToken属性,控制 取消axios

fetch
1.是基于promise实现的,也可以结合async/await。
2.请求默认是不带cookie的,需要设置fetch(URL,{credentials:’include’})。Credentials有三种参数:same-origin,include,*
3.服务器返回400 500 状态码时并不会reject,只有网络出错导致请求不能完成时,fetch才会被reject。
4.所有版本的 IE 均不支持原生 Fetch。
5.是widow的一个方法;

ajax

1.ajax本身是针对mvc编程,不符合现在前端mvvm的浪潮
2.基于原生XHR开发,XHR本身的架构不清晰
3.不符合关注分离的原则
4.配置和调用方式非常混乱,而且基于事件的异步模型不友好

下面附上本人对axios的一些封装,详情请看代码(根据不同的项目需求对axios的请求拦截与响应拦截进行不同的处理)

const TimeOut = 3600 // 定义token超时时间
const service = axios.create({
baseURL: process.env.VUE_APP_BASE_API,
timeout: 5000
})
// 请求拦截
service.interceptors.request.use(config => {
// 注入token
// config是配置信息,一定要return出去
if (store.getters.token) {
if (IsCheckOut()) {
// 如果为真,则说明超时,需要删除用户token,资料。退到登录页面
store.dispatch('user/logout')
router.push('/login')
return Promise.reject(new Error('登录超时,请重新登录!'))
}
// 只有在有token的情况下才有必要去检查是否超时
config.headers['Authorization'] = `Bearer ${store.getters.token}`
}
return config
}, error => {
return Promise.reject(error)
})
// 响应拦截
service.interceptors.response.use(response => {
// axios 默认为数据加一层data
const { success, message, data } = response.data(需要根据自己项目中后端返回数据的字段进行解构)
if (success) {
return data
} else {
// 提示错误信息
Message.error(message)
// 业务已经错了?还能进去then(): 不能,应该进去catch
return Promise.reject(new Error(message))
}
}, error => {
// 后端被动介入超时处理
// error 信息 里面 response的对象
console.log(error)
if (error.response && error.response.data && error.response.data.code === 10002) {
// 当等于10002的时候 表示 后端告诉我token超时了
store.dispatch('user/logout') // 登出action 删除token
router.push('/login')
} else {
Message.error(error.message)
}
return Promise.reject(error) // 返回执行错误,让当前执行链跳出成功,直接进去catch
})
// 是否超时
// 超时逻辑 当前时间戳 - 缓存时间戳 > TimeOut
function IsCheckOut() {
const currentTime = Date.now() // 设置当前时间戳
const timeStamp = getTimeOut() // 缓存时间戳
return (currentTime - timeStamp) / 1000 > TimeOut
}
export default service

总结
axios fetch 前两者基于promise ajax后者主要利用callback的形式

Axios,fetch,ajax的区别的更多相关文章

  1. axios与ajax的区别及优缺点

    区别:axios是通过Promise实现对ajax技术的一种封装,就像jquery对ajax的封装一样,简单来说就是ajax技术实现了局部数据的刷新,axios实现了对ajax的封装,axios有的a ...

  2. axios与ajax的区别及中文用户指南

    Ajax: Ajax 即“Asynchronous Javascript And XML”(异步 JavaScript 和 XML),是指一种创建交互式网页应用的网页开发技术. $.ajax({ ty ...

  3. Jquery ajax, Axios, Fetch区别

    1.   Jquery ajax, Axios, Fetch区别之我见 2.   ajax.axios.fetch之间的详细区别以及优缺点

  4. vue-d2admin-axios异步请求登录,先对比一下Jquery ajax, Axios, Fetch区别

    先说一下对比吧 Jquery ajax, Axios, Fetch区别之我见 引言 前端技术真是一个发展飞快的领域,我三年前入职的时候只有原生XHR和Jquery ajax,我们还曾被JQuery 1 ...

  5. Axios & fetch api & Promise & POST

    Axios & fetch api & Promise & POST https://github.com/axios/axios https://appdividend.co ...

  6. Axios 取消 Ajax 请求

    Axios 取消 Ajax 请求 Axios XMLHttpRequest https://caniuse.com/?search=XMLHttpRequest https://developer.m ...

  7. 学习axios必知必会(2)~axios基本使用、使用axios前必知细节、axios和实例对象区别、拦截器、取消请求

    一.axios的基本使用: ✿ 使用axios前必知细节: 1.axios 函数对象(可以作为axios(config)函数使用去发送请求,也可以作为对象调用方法axios.request(confi ...

  8. 异步请求与中断 ( XHR,Axios,Fetch对比 )

    随着AJAX技术的诞生,前端正式进入了局部刷新和前后端分离的新时代,最初的服务请求技术是XHR,随着技术发展和ES6的诞生,jquery ajax,axios,fetch 等技术的产生让前端的异步请求 ...

  9. Axios发送AJAX请求

    目录 Axios 特征 axios提供主要三种发起请求的方式 方式一:直接axios实例直接call方式 方式二:通过axios实例提供的不同http请求方式的方法 方式三:其实是从第二种方式中单独提 ...

  10. axios 或 ajax 请求文件

    axios 或 ajax 请求文件 axios({ url: path + '/monitor/exportPicture' + '?access_token=' + getToken(), meth ...

随机推荐

  1. Hive - [08] 数据仓库物理模型设计

    分区 分区是将表的数据按照某个列的值进行划分和存储的一种方式.通过分区,可以将数据按照特定的维度进行组织,提高查询效率和数据管理的灵活性. 一.分区的优势 提高查询性能:通过分区,可以将数据按照特定的 ...

  2. Selenium 项目搭建过程

    Selenium 环境搭建多多少少大概有4.5次了,每次都有东西遗忘,整理下大概的过程: 安装python,下载exe文件 C:\Users\lic\AppData\Local\Programs\Py ...

  3. vim使用技巧记录

    1.查找 '/' + 要找的字符串(正则表达式) + Enter # 查找偏移 'n': 查找下一个 'N': 查找上一个 大小写敏感性:字符串尾接\c不敏感,\C敏感 可以~/.vimrc在配置中配 ...

  4. 【练习回顾】dfs迷宫+路径打印

    很直接的dfs.递归+栈--不知道以后会不会生疏 进入一次dfs,相当于走一步,入栈:结束一次dfs,相当于这一步考虑结束,出栈 笑死,y1竟然是一个函数 突然发现写的有点槽,可以把dfs形式化为&q ...

  5. @ComponentScan @MapperScan 拆分项目的时候,这两个注解很重要

    今天,在做项目拆分的时候遇到了个问题,就是将service和dao层拆完之后,项目启动不起开了,如图: 最终解决办法,在启动类上增加两个注解搞定: @ComponentScan(basePackage ...

  6. DevEco Studio 常用设置【自用】

    设置为中文 API参考设置悬浮 始终定位打开的文件,单击预览免打开 保存时自动格式化和热更新 属性单独一行

  7. pip和pip3如何更新

    pip pip install --upgrade pip pip3 pip3 install --upgrade pip

  8. 递归--java进阶day08

    1.递归 2.案例 1.案例一 求出5的阶乘 我们会发现其中存在规律 我们先定义一个带返回值的方法,方便调用者使用 当给的数是1时,1的阶乘还是1,我们就可以直接返回 如果走了else,说明给的数不是 ...

  9. 代码块--java进阶day03

    1.代码块 1.局部代码块 定义在方法中的一对大括号,可以提早释放内存,走完{}里的逻辑后就会被释放,在之后的编程中无法使用 2.构造代码块 位置在类中,方法外的{},在构造方法执行的时候,构造代码块 ...

  10. Ubuntu24使用Wine运行Windows程序安装微信

    Ubuntu24使用Wine运行Windows程序安装微信 2024.11.8:好消息!微信发布Linux版本了,微信主站Linux版本客户端下载页面:https://linux.weixin.qq. ...