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. Oracle - [03] 存储过程

    一.什么是存储过程 存储过程是一种数据库对象,是一种存储在数据库中的可执行程序,是一些经过编写.编译而存在数据库中的SQL语句集. 二.创建存储过程的语法 create or replace proc ...

  2. 解密注意力机制:为什么Flash Attention这么屌?

    背景回顾:什么是大语言模型(LLM)? 在进入注意力机制的细节之前,我们先了解一下什么是大语言模型(LLM).简单来说,LLM是一种通过深度学习技术训练的大规模神经网络模型,用于处理和生成自然语言.L ...

  3. 云服务器Linux 时间与本地时间不一致

      云服务器Linux 时间与本地时间不一致 问题解释: 云服务器和本地计算机之间的时间不一致可能是因为它们使用的时间同步服务不同,或者云服务器没有配置自动对时. 解决方法: 手动同步时间:可以使用d ...

  4. LaTeX使用记录

    安装与使用 曾在Windows10下装过MikTeX,并配合vscode插件LaTeX Workshop使用过一段时间:这次转到wsl2中,并使用texlive,所以插件的配置json需要小修改 参考 ...

  5. [python]pip换源详解

    [python]pip换源详解 前言 ‍ 现有的各个网站上的pip换源方式,很零散,或者是很单调的重复,又或者只是给出命令,尽管这通常就够用了. 但是,我希望汇总一下,然后再结合pip的官方文档来做一 ...

  6. 微信小程序反编译~2022年

    小程序反编译 前言 微信小程序反编译可以通过对小程序包进行反编来获取小程序源码,在一次信息收集的过程中对某公司的APP.微信公众号.小程序进行抓包数据分析寻找接口等有用的信息时,在抓包过程中由于微信的 ...

  7. Flask应用实战经验总结:使用工厂函数创建app与uWSGI服务部署启动失败解决方案

    在 Flask 应用开发中,使用工厂函数创建应用实例,并借助 uWSGI 服务进行部署,是常见且高效的组合. 然而,在实际操作过程中,uWSGI 配置文件与应用启动函数之间的关系复杂,容易引发各种问题 ...

  8. 关于普通程序员该如何参与AI学习的三个建议以及自己的实践

    大部分程序员在学习大语言模型的时候都比较痛苦,感觉AI是如此之近又如此之远,仿佛能搞明白一点,又好像什么也没明白.就像我们在很远的地方看珠穆拉玛峰,感觉它就像一个不大的山包,感觉只要自己做足准备咬咬牙 ...

  9. unigui如何直接显示一个PDF文件【13】

    这个问题有点搞笑. PDF.js v1.9.426 (build: 2558a58d) 信息:Unexpected server response (204) while retrieving PDF ...

  10. spring项目使用EMQX,使用@Autowired注入失败报错空指针问题记录

    目录 java客户端使用MQTT订阅消息大致流程 MQTTConnect部分代码 MQTTListener部分代码 问题分析 问题原因 解决方法 总结 参考 java客户端使用MQTT订阅消息大致流程 ...