当前位置: 首页 > article >正文

`fetch` 和 `axios`的前端使用区别

🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉
欢迎访问的个人博客:https://swzbk.site/,加好友,拉你入福利群
🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉

fetchaxios` 是前端常用的两种 HTTP 客户端,以下是它们的核心区别及适用场景:

一、本质区别

特性fetchaxios
类型浏览器原生 API(部分环境需 polyfill)第三方库(需通过 npm/yarn 安装)
底层实现基于 Promise基于 Promise,封装了 XMLHttpRequest

二、核心功能对比

1. 请求与响应
功能fetchaxios
基本用法fetch(url).then(res => res.json())axios.get(url).then(res => res.data)
请求配置需手动设置 headersmethod 等参数支持 config 对象统一配置(如 axios({ method, url, data })
默认响应响应体需手动解析(如 .json().blob()自动解析为 JSON(res.data 直接获取)
2. 浏览器兼容性
环境fetchaxios
现代浏览器支持(Chrome/Firefox/Edge 等)支持
旧浏览器(如 IE)需单独引入 whatwg-fetch polyfill原生支持(基于 XMLHttpRequest)
3. 高级功能
功能fetchaxios
请求拦截器无内置支持,需手动封装支持 axios.interceptors.request.use()
响应拦截器无内置支持,需手动封装支持 axios.interceptors.response.use()
取消请求需使用 AbortController内置 CancelToken
上传进度监听需手动计算(ReadableStream 或第三方库)内置 onUploadProgress 回调
下载进度监听需手动计算(response.body.pipeThrough()内置 onDownloadProgress 回调
4. 错误处理
场景fetchaxios
网络错误拒绝 Promise(如断网)拒绝 Promise
HTTP 错误状态码不会 拒绝 Promise(需手动检查 res.ok 拒绝 Promise(如 404/500 状态码)
5. 浏览器 vs Node.js
环境fetchaxios
浏览器原生支持支持
Node.js需额外引入(如 node-fetch原生支持(内置 http/https 模块封装)

三、典型使用场景

推荐用 axios 的场景
  1. 文件上传/下载

    • 需显示进度条(onUploadProgress)。
    • 多文件上传需合并请求(FormData 封装+单次请求)。
    • 示例:
      axios.post('/upload', formData, {onUploadProgress: (e) => console.log(`上传进度:${Math.round((e.loaded/e.total)*100)}%`),
      });
      
  2. 复杂交互

    • 需要请求/响应拦截(如添加全局 token、统一错误处理)。
    • 支持并发请求(axios.all())。
  3. 兼容性要求高

    • 需兼容 IE 或旧浏览器。
推荐用 fetch 的场景
  1. 轻量需求

    • 简单 GET/POST 请求,无需额外功能。
    • 示例:
      fetch('/api/data', { method: 'POST', body: JSON.stringify(data) }).then(res => res.json());
      
  2. 减少依赖

    • 不想引入第三方库(如 React Native 原生支持 fetch)。

四、如何选择?

需求axiosfetch
上传进度条✅ 内置支持❌ 需手动实现
浏览器兼容性(如 IE)✅ 原生支持❌ 需 polyfill
拦截器、取消请求等高级功能✅ 内置支持❌ 需手动封装
轻量应用/减少依赖❌ 增加打包体积✅ 原生无依赖
Node.js 环境✅ 原生支持❌ 需额外引入模块

总结

  • 如果项目需要在现代浏览器中使用且对功能要求简单,Fetch 是个不错的选择,优点在于无需额外依赖、语法简洁。但需要注意手动处理错误、转换响应和取消请求的问题。
  • 如果需要更丰富的功能(如请求/响应拦截、自动 JSON 解析、全局配置、取消请求等)以及对 IE 或 Node.js 的兼容性要求较高,Axios 是更佳的解决方案。

🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉
欢迎访问的个人博客:https://swzbk.site/,加好友,拉你入福利群
🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉
`

相关文章:

`fetch` 和 `axios`的前端使用区别

🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉🎉 欢迎访问的个人博客&am…...

大语言模型的多垂类快速评估与 A/B 测试

简介 行业领先的模型构建企业携手澳鹏(Appen)开展了一项极具挑战性的项目。针对 3 至 6 个大型语言模型(LLM),在广泛的通用领域及复杂专业领域(如医疗保健、法律、金融、编程、数学和汽车行业等&#xff0…...

【RabbitMQ】RabbitMQ如何保证消息不丢失?

为了保证消息不丢失,需要在生产者、RabbitMQ本身和消费者三个环节采取相应措施。 1.生产者端:确保消息发送成功 1.1开启消息确认机制(Publisher Confirms) 原理: 生产者发送消息后,RabbitMQ会返回一个确认(ACK),表示消息已成功…...

RAGFlow + LlamaIndex 本地知识库RAG增强架构与实现直播智能复盘

一、需求分析与架构设计 基于 RAGFlow LlamaIndex 本地知识库RAG 扩展直播话术合规与复盘系统,需构建 实时流处理、多模态合规引擎、智能复盘分析 三层能力。以下是完整架构图与技术方案: 二、核心模块技术方案 1. 直播流实时处理(输入层→…...

《UNIX网络编程卷1:套接字联网API》第2章 传输层:TCP、UDP和SCTP

《UNIX网络编程卷1:套接字联网API》第2章 传输层:TCP、UDP和SCTP 2.1 传输层的核心作用与协议选型 传输层是网络协议栈中承上启下的核心层,直接决定应用的通信质量。其主要职责包括: 端到端通信:屏蔽底层网络细节&am…...

阿里云平台服务器操作以及发布静态项目

目录: 1、云服务器介绍2、云服务器界面3、发布静态项目1、启动nginx2、ngixn访问3、外网访问测试4、拷贝静态资源到nginx目录下并重启nginx 1、云服务器介绍 2、云服务器界面 实例详情:里面主要显示云服务的内外网地址以及一些启动/停止的操作。监控&…...

【大模型实战篇】使用GPTQ量化QwQ-32B微调后的推理模型

1. 量化背景 之所以做量化,就是希望在现有的硬件条件下,提升性能。量化能将模型权重从高精度(如FP32)转换为低精度(如INT8/FP16),内存占用可减少50%~75%。低精度运算(如INT8&#xf…...

Spring WebFlux之流式输出

🎉🎉🎉🎉🎉🎉 欢迎访问的个人博客:https://swzbk.site/,加好友,拉你入福利群 🎉🎉🎉🎉🎉🎉 流式输…...

基于springboot医疗平台系统(源码+lw+部署文档+讲解),源码可白嫖!

摘要 信息化时代,各行各业都以网络为基础飞速发展,而医疗服务行业的发展却进展缓慢,传统的医疗服务行业已经逐渐不满足民众的需求,有些还在以线下预约挂号的方式接待病人,为此设计一个医疗平台系统很有必要。此类系统…...

Stable Diffusion lora训练(一)

一、不同维度的LoRA训练步数建议 2D风格训练 数据规模:建议20-50张高质量图片(分辨率≥10241024),覆盖多角度、多表情的平面风格。步数范围:总步数控制在1000-2000步,公式为 总步数 Repeat Image Epoch …...

网络空间安全(37)获取webshell方法总结

一、直接上传获取Webshell 这是最常见且直接的方法,利用网站对上传文件的过滤不严或存在漏洞,直接上传Webshell文件。 常见场景: 许多PHP和JSP程序存在此类漏洞。例如,一些论坛系统允许用户上传头像或心情图标,攻击者可…...

第十三次CCF-CSP认证(含C++源码)

第十三次CCF-CSP认证 跳一跳满分题解 碰撞的小球满分题解遇到的问题 棋局评估满分题解 跳一跳 题目链接 满分题解 没什么好说的 基本思路就是如何用代码翻译题目所给的一些限制,以及变量应该如何更新,没像往常一样给一个n,怎么读入数据&…...

【Agent】OpenManus-Prompt组件详细分析

1. 提示词架构概述 OpenManus 的提示词组件采用了模块化设计,为不同类型的智能体提供专门的提示词模板。每个提示词模块通常包含两种核心提示词:系统提示词(System Prompt)和下一步提示词(Next Step Prompt&#xff0…...

swagger ui 界面清除登录信息的办法

我们在开发过程中,用swagger ui 测试接口的时候,可能会要修改当前登录的用户。 但是如果我们在谷歌中对调试的本地swagger ui 登录地址存储过账户密码,每次启动项目调试之后,都会自动登录swagger ui ,登录界面一闪就…...

TensorFlow 的基本概念和使用场景

TensorFlow 是一个由 Google 开发的开源机器学习框架,主要用于构建和训练深度学习模型。下面是一些 TensorFlow 的基本概念和使用场景: 基本概念: 张量(Tensor):在 TensorFlow 中,数据以张量的…...

基于x11vnc的ubuntu远程桌面

1、安装VNC服务 sudo apt install x11vnc -y2、创建连接密码 sudo x11vnc -storepasswd3、安装lightdm服务 x11vnc 在 默认的 GDM3 中不起作用,因此需要使用 lightdm 桌面管理环境 sudo apt install lightdm -y切换至lightdm,上一步已经切换则跳过该…...

Cursor解锁Claude Max,助力AI编程新突破!

Cursor 最新推出的 Claude Max 模型,以其卓越的性能和创新的能力,正在重新定义我们对 AI 辅助编程的认知。这款搭载 Claude3.7 大脑的超级模型,不仅具备超强智能,还凭借一系列技术突破,向传统 AI 编程工具发起了挑战。…...

created在vue3 script setup中的写法

在 Vue 2 里&#xff0c;created 是一个生命周期钩子函数&#xff0c;会在实例已经创建完成之后被调用&#xff0c;主要用于在实例初始化之后、数据观测和 event/watcher 事件配置之前执行代码。而在 Vue 3 的 <script setup> 语法糖里&#xff0c;不再有像 Vue 2 那样直…...

GenICam标准

GenICam的目标是为所有类型的相机提供一个统一的编程接口。无论相机使用的是哪种传输协议或实现了哪些功能&#xff0c;编程接口&#xff08;API&#xff09;都是一样的。 GenICam&#xff08;Generic Interface for Cameras&#xff09;是一个为工业相机和图像采集设备设计的…...

ESP8266 与 ARM7 接口-LPC2148 创建 Web 服务器以控制 LED

ESP8266 与 ARM7 接口-LPC2148 创建 Web 服务器以控制 LED ESP8266 Wi-Fi 收发器提供了一种将微控制器连接到网络的方法。它被广泛用于物联网项目,因为它便宜、体积小且易于使用。 在本教程中,我们将 ESP8266 Wi-Fi 模块与 ARM7-LPC2148 微控制器连接,并创建一个 Web 服务…...

​智享三代 AI 无人直播系统:颠覆传统,重塑直播新格局

在当今数字化浪潮席卷全球的时代&#xff0c;直播行业作为互联网经济的重要组成部分&#xff0c;正以前所未有的速度蓬勃发展。从最初的娱乐直播兴起&#xff0c;到如今电商直播、知识付费直播等多元业态百花齐放&#xff0c;直播已然成为人们生活和商业活动中不可或缺的一环。…...

通过C#脚本更改材质球的参数

// 设置贴图Texture mTexture Resources.Load("myTexture", typeof(Texture )) as Texture;material.SetTexture("_MainTex", mTexture );// 设置整数material.SetInt("_Int", 1);// 设置浮点material.SetFloat("_Float", 0.1f);// 设…...

FPGA管脚约束

目录 前言 一、IO约束 二、延迟约束 前言 IO约束包括管脚约束和延迟约束。 一、IO约束 对管脚进行约束&#xff0c;对应的约束语句&#xff1a; set_property -dict {PACKAGE_PIN AJ16 IOSTANDARD LVCMOS18} [get_ports "led[0]" ] 上面是单端的管脚&…...

已在此计算机上安装相同或更高版本的 .NET Framework 4”安装报错问题

安裝低版本的 .netFramework會被拒絕 需要做兩件事 1&#xff0c;允許windows安裝低版本的.net framework “已在此计算机上安装相同或更高版本的 .NET Framework 4”安装报错问题-CSDN博客 2,設置完成後重新安裝低版本的 .net framework,要用對應開發版本的 Win10 电脑安…...

如何判断 MSF 的 Payload 是 Staged 还是 Stageless(含 Meterpreter 与普通 Shell 对比)

在渗透测试领域&#xff0c;Metasploit Framework&#xff08;MSF&#xff09;的 msfvenom 工具是生成 Payload&#xff08;载荷&#xff09;的核心利器。然而&#xff0c;当我们选择 Payload 时&#xff0c;经常会遇到一个问题&#xff1a;这个 Payload 是 Staged&#xff08;…...

【万字总结】前端全方位性能优化指南(一)——Brotli压缩、CDN智能分发、资源合并

前言 2025年前端技术前沿呈现三大核心趋势:​AI深度赋能开发全流程,智能工具如GitHub Copilot X和Cursor实现代码生成、实时协作与自动化审查,开发效率提升3倍以上;性能与架构革新,WebAssembly 2.0支持多线程与Rust内存优化,边缘计算将渲染延迟压至50ms内,微前端Module …...

二.使用ffmpeg对原始音频数据重采样并进行AAC编码

重采样&#xff1a;将音频三元组【采样率 采样格式 通道数】之中的任何一个或者多个值改变。 一.为什么要进行重采样&#xff1f; 1.原始音频数据和编码器的数据格式不一致 2.播放器要求的和获取的数据不一致 3.方便运算 二.本次编码流程 1.了解自己本机麦克风参数&#x…...

实现前端.ttf字体包的压缩

前言 平常字体包都有1M的大小&#xff0c;所以网络请求耗时会比较长&#xff0c;所以对字体包的压缩也是前端优化的一个点。但是前端如果想要特点字符打包成字体包&#xff0c;网上查阅资料后&#xff0c;都是把前端代码里面的字符获取&#xff0c;但是对于动态的内容&#xf…...

uni-app集成保利威直播、点播SDK经验FQ(二)|小程序直播/APP直播开发适用

通过uniapp集成保利威直播、点播SDK来开发小程序/APP的视频直播能力&#xff0c;在实际开发中可能会遇到的疑问和解决方案&#xff0c;下篇。更多疑问请咨询19924784795。 1.ios不能后台挂起uniapp插件 ios端使用后台音频播放和画中画功能&#xff0c;没有在 manifest.json 进…...

Spring Framework 中 BeanDefinition 是什么

BeanDefinition 是 Spring Framework 中一个核心的接口&#xff0c;它描述了一个 Bean 的定义。你可以把它看作是 Spring IoC 容器中 Bean 的“蓝图”或“配置元数据”。它包含了 Spring 容器创建、配置和管理 Bean 所需的所有信息。 BeanDefinition 中包含的信息&#xff1a;…...