WHAT - xmlhttprequest vs fetch vs wretch
目录
- 前言
- 1. XMLHttpRequest (XHR)
- 2. fetch
- 3. wretch
- 总结
- fetch
- 1. 简洁性和易用性
- 2. 错误处理
- 3. 默认行为和功能扩展
- 4. 请求和响应的处理
- 5. 跨域请求和 CORS
- 6. 现代 Web 开发需求
- fetch vs xhr 代码示例
- 使用 XMLHttpRequest
- 使用 fetch
- 代码对比
前言
根据标题我们可以知道今天主要介绍三个内容:xmlhttprequest、fetch、wretch。这几个工具都是用于在 JavaScript 中进行 HTTP 请求的,但是它们有不同的特点和使用场景。我们来逐一分析。
1. XMLHttpRequest (XHR)
官方文档
-
特点:
- 这是一个较老的 API,用于在浏览器中进行 HTTP 请求。
- 支持同步和异步请求(虽然同步请求在现代浏览器中已不推荐使用)。
- 配置和使用相对复杂,需要处理更多的回调和状态管理。
-
示例:
var xhr = new XMLHttpRequest(); xhr.open('GET', 'https://api.example.com/data', true); xhr.onreadystatechange = function () {if (xhr.readyState === 4 && xhr.status === 200) {console.log(xhr.responseText);} }; xhr.send();
2. fetch
官方文档
-
特点:
- 是现代浏览器中推荐使用的 API,用于进行 HTTP 请求。
- 基于 Promises,支持链式调用和更简洁的语法。
- 默认情况下只处理 HTTP 响应的状态码,不会自动抛出错误,需手动检查响应的状态。
-
示例:
fetch('https://api.example.com/data').then(response => {if (!response.ok) {throw new Error('Network response was not ok');}return response.json();}).then(data => console.log(data)).catch(error => console.error('There was a problem with your fetch operation:', error));
3. wretch
官方文档
-
特点:
- 是一个第三方库,建立在
fetch
之上,提供更强大的功能和更简洁的语法。 - 支持链式调用、请求拦截器、响应拦截器、自动解析 JSON 等。
- 可以通过插件和中间件扩展功能。
- 是一个第三方库,建立在
-
示例:
import wretch from 'wretch';wretch('https://api.example.com/data').get().json().then(data => console.log(data)).catch(error => console.error('There was a problem with your request:', error));
总结
XMLHttpRequest
是较老的 API,适用于兼容性要求较高的场景,但使用起来较为复杂。fetch
是现代的原生 API,提供了更简洁的语法和基于 Promises 的异步处理。wretch
是一个基于fetch
的库,进一步简化了 API,并提供了更多功能和灵活性,适用于需要更复杂请求处理的场景。
选择哪个工具取决于你的项目需求和个人偏好。如果你需要兼容旧浏览器或在已有代码中使用,XMLHttpRequest
可能是必要的。如果你倾向于现代化的编程风格,fetch
是推荐的选择。如果你想要额外的功能和更易用的 API,wretch
是一个很好的选择。
fetch
XMLHttpRequest
(XHR) 在它推出的时代是处理浏览器中 HTTP 请求的主要方法,但随着技术的发展和需求的变化,开发者们发现了它的一些不足之处,这些不足促使了 fetch
规范的推出。
以下是一些主要原因:
1. 简洁性和易用性
-
XMLHttpRequest
:- 处理回调函数和状态变化较复杂,需要手动管理许多状态和回调(如
onreadystatechange
)。 - 语法较繁琐,需要额外的代码来检查请求状态和处理错误。
- 处理回调函数和状态变化较复杂,需要手动管理许多状态和回调(如
-
fetch
:- 基于 Promises,使得异步代码的编写更简单、易读,支持链式调用。
- 更加简洁的语法,消除了繁琐的回调和状态管理。
2. 错误处理
-
XMLHttpRequest
:- 错误处理依赖于检查
status
代码,并且对于网络错误(如无法连接服务器)通常需要额外的逻辑来处理。
- 错误处理依赖于检查
-
fetch
:- 主要依赖于 Promises 的
.catch()
方法来处理请求错误。 - 只会对网络错误抛出异常,而 HTTP 错误状态(如 404 或 500)仍会被当作正常的响应处理,需要手动检查响应状态。
- 主要依赖于 Promises 的
3. 默认行为和功能扩展
-
XMLHttpRequest
:- 不支持一些现代网络请求的功能,如流式处理。
- 处理 JSON 数据时需要手动解析,且不支持一些高级的请求功能。
-
fetch
:- 内置了对流的支持,能够处理大数据的流式读取。
- 自动处理请求和响应的序列化和反序列化(如 JSON)。
4. 请求和响应的处理
-
XMLHttpRequest
:- 处理请求和响应的流程相对复杂,需要设置多个事件处理函数。
-
fetch
:- 通过一个简洁的 API 来配置请求,响应处理更为直接。
- 提供了更多灵活的配置选项,如自定义请求头和方法。
5. 跨域请求和 CORS
-
XMLHttpRequest
:- 跨域请求的处理较复杂,需要配置 CORS 头部,并且有时需要处理更多的兼容性问题。
-
fetch
:- 内置对 CORS 的支持,配置更简单,并且提供了更细粒度的控制。
6. 现代 Web 开发需求
-
XMLHttpRequest
:- 设计时没有考虑到现代 Web 开发的一些需求,如更复杂的请求、响应流处理和更高效的异步处理。
-
fetch
:- 设计时考虑了现代 Web 的需求,支持更复杂的请求和响应处理,更好地与现代 JavaScript 的异步处理模式(如 async/await)兼容。
总之,fetch
的推出是为了满足现代 Web 开发对更简洁、灵活和强大的 HTTP 请求处理的需求。它不仅改进了 XMLHttpRequest
的不足,还融入了更符合当前开发需求的设计理念。
fetch vs xhr 代码示例
下面是用 XMLHttpRequest
和 fetch
处理相同 HTTP 请求的代码示例。这将有助于比较它们的语法和处理方式。
使用 XMLHttpRequest
假设我们要从一个 API 获取 JSON 数据,并处理响应。
代码示例:
// 创建 XMLHttpRequest 对象
var xhr = new XMLHttpRequest();// 配置请求:GET 方法,请求 URL,异步方式
xhr.open('GET', 'https://api.example.com/data', true);// 设置响应类型为 JSON
xhr.responseType = 'json';// 监听请求状态变化
xhr.onreadystatechange = function() {if (xhr.readyState === 4) { // 请求完成if (xhr.status === 200) { // 请求成功console.log(xhr.response); // 打印响应数据} else {console.error('请求失败,状态码:', xhr.status);}}
};// 发送请求
xhr.send();
使用 fetch
代码示例:
// 使用 fetch 发起 GET 请求
fetch('https://api.example.com/data').then(response => {if (!response.ok) { // 检查响应状态throw new Error('网络响应不是 OK');}return response.json(); // 解析 JSON 数据}).then(data => {console.log(data); // 打印响应数据}).catch(error => {console.error('请求失败:', error); // 打印错误信息});
代码对比
-
创建请求:
XMLHttpRequest
:需要创建一个对象,设置请求方法和 URL,调用open
方法。fetch
:直接调用fetch
函数并传递 URL 和配置选项。
-
配置请求:
XMLHttpRequest
:需要额外设置请求的响应类型,并处理请求的状态变化(使用onreadystatechange
)。fetch
:响应解析(如 JSON)通常在then
链中处理,不需要配置响应类型。
-
处理响应:
XMLHttpRequest
:需要检查readyState
和status
,然后手动解析响应。fetch
:基于 Promises 的链式调用,自动处理解析和错误捕获,更直观。
-
错误处理:
XMLHttpRequest
:通常需要自己处理各种可能的错误情况。fetch
:通过catch
捕获网络错误和其他异常,错误处理更为集中和简洁。
-
响应类型:
XMLHttpRequest
:响应类型需手动设置(如responseType = 'json'
)。fetch
:通常解析为 JSON 或其他格式(如response.text()
),无须手动设置响应类型。
总体来说,fetch
提供了更现代和简洁的 API,使得 HTTP 请求的处理更为方便和直观。
相关文章:

WHAT - xmlhttprequest vs fetch vs wretch
目录 前言1. XMLHttpRequest (XHR)2. fetch3. wretch总结 fetch1. 简洁性和易用性2. 错误处理3. 默认行为和功能扩展4. 请求和响应的处理5. 跨域请求和 CORS6. 现代 Web 开发需求 fetch vs xhr 代码示例使用 XMLHttpRequest使用 fetch代码对比 前言 根据标题我们可以知道今天主…...

吴恩达老师机器学习作业-ex7(聚类)
导入库,读取数据,查看数据类型等进行分析,可视化数据 import matplotlib.pyplot as plt import numpy as np import scipy.io as sio#读取数据 path "./ex7data2.mat" data sio.loadmat(path) # print(type(data)) # print(data…...

lombok 驼峰命名缺陷,导致后台获取参数为null的解决办法
1.问题: 下面是我定义一个请求类的属性,采用Lombok注解,自动构建get和set方法。 Schema(description "父组织编码", requiredMode Schema.RequiredMode.REQUIRED) private String pOrgCode; 遇到这种命名,你会发现在…...

【dockerpython】亲测有效!适合新手!docker创建conda镜像+容器使用(挂载、端口映射、gpu使用)+云镜像仓库教程
文章目录 docker基本概念简介配置镜像加速源创建conda镜像1. 写 Dockerfile文件2. 创建镜像3. 创建容器并测试 容器的使用1. wsl挂载2. 端口映射3. 补充-gpu 云镜像仓库使用1. 登录2. 将本地镜像上传至云镜像仓库3. 从云镜像仓库下载镜像到本地 docker基本概念简介 简单来讲&a…...

矩阵,求矩阵秩、逆矩阵
求矩阵秩的方法: 高斯消元法:通过行变换将矩阵化为行阶梯形矩阵,然后数非零行的数量。LU分解:通过分解矩阵成上下三角矩阵,计算非零对角元素的数量。SVD分解:通过奇异值分解,计算非零奇异值的数…...

指针和const
const int* ptr,int* const ptr,const int* const ptr 这三种指针定义有什么区别?用法有什么不同? 指向的地址是否可变指向的地址上存储的内容是否可变const属性const int* ptr可改变不可改*ptr具有const属性int* const pts不可改…...

基于C#调用文心一言大模型制作桌面软件(可改装接口)
目录 开发前的准备账号注册应用创建应用接入 开始开发创建项目设计界面使用 AK,SK 生成鉴权签名窗体代码 百度智能云千帆大模型平台什么是百度智能云千帆大模型平台模型更新记录 开发前的准备 账号注册 访问百度智能云平台,通过百度账号登录或手机号验证…...

VScode插件安装
一、常用插件 Chinese (Simplified) (简体中文) Language Pack for Visual Studio Code vscode 中文插件 Auto Rename Tag 闭合标签 Path Intellisense 一个非常实用的工具,它提供了文件路径的自动补全功能,可以极大地提高开发效率。路径自动补全、…...

《Milvus Cloud向量数据库指南》——高可用黄金标准:深入解析与业务策略考量
高可用黄金标准:深入解析与业务策略考量 在信息技术飞速发展的今天,高可用性(High Availability, HA)已成为衡量企业IT系统性能与稳定性的关键指标之一。它不仅仅关乎技术层面的优化与配置,更是企业保障业务连续性、提升客户体验、增强市场竞争力的重要基石。尽管高可用性…...

sqli-labs注入练习1,2关
sqli-labs第一关 判断是否存在sql注入 可见,根据输入数字的不同,结果也不同 判断sql语句是否是拼接,且是字符型还是数字型 由上可见,这关指定是字符型且存在sql注入漏洞 使用联合注入 第一步:首先知道表格有几列&…...

B站宋红康JAVA基础视频教程个人笔记chapter04
文章目录 1.IDEA安装好后的一些设置和学习1.1关于IDEA内部jdk版本的设置1.2 一些样式以及快捷键的常用设置(强烈推荐) 2.工程与模块管理3.如何彻底的卸载IDEA 1.IDEA安装好后的一些设置和学习 1.1关于IDEA内部jdk版本的设置 1.File—>Project Struc…...

关于java枚举为什么可以拿来当单例实现这件事看看ikun怎么说
为什么枚举可以保证单例 枚举可以保证单例的原因主要可以归结为以下几个方面: 1. 枚举的实例化过程 线程安全:枚举的实例化过程是由JVM控制的,在类加载时就完成了枚举常量的初始化。由于这个初始化过程是线程安全的(JVM在加载枚…...

Hugging Face下载模型
1、安装 huggingface-cli pip install -U huggingface_hub 2、设置环境变量(如果你打算使用 HF_ENDPOINT 环境变量来指定下载镜像站点): export HF_ENDPOINThttps://hf-mirror.com 3、使用 huggingface-cli 下载模型: 使用下面的命令来下…...

JVM-垃圾回收
什么是JVM的垃圾回收? 垃圾回收(Garbage Collection, GC)是Java虚拟机(JVM)自动管理内存的一种机制,其目的是自动回收不再使用的对象所占用的内存空间,以防止内存泄漏和提升内存利用效率。 运…...

8.C基础_指针基础
指针概述 1、定义与初始化 形式:<数据类型>* <变量名> <地址>; int a 10; int *p &a; 指针的类型不同,p时的偏移地址量不同,偏移地址 sizeof(类型)Byte 注意点: 指针的类型要与数据的类型保持一…...

安泰功率放大器使用注意事项有哪些内容和要求
功率放大器是一种广泛应用于音频系统、通信系统和实验室等领域的设备,其作用是将输入信号放大到足够大的功率输出。为了安全使用功率放大器并保证其性能和寿命,以下是一些使用功率放大器时需要注意的事项和要求。 一、选择适当的功率放大器: …...

windows下,使用vs code远程连接云服务器【以CentOS7为例】
windows下,使用vs code远程连接云服务器 1. 下载VS code并准备相关插件2. 使用Remote - SSH远程控制Linux 1. 下载VS code并准备相关插件 1. VS code官网: 下载地址:https://code.visualstudio.com/Download下载合适版本的vs code。 2. 推荐…...

x264 中像素扩边算法源码分析
介绍 在视频编码中,特别是在使用x264这样的H.264/MPEG-4 AVC编码器时,像素扩边(或称为边缘扩展)是一项重要的预处理步骤。像素扩边的目的是在帧的边缘添加额外的像素,这样在编码过程中可以应用滤波器,如去块滤波器(deblocking filter)和水平/垂直滤波器,而不会受到帧…...

数据结构——双链表详解(超详细)
前言: 小编在之前已经写过单链表的创建了,接下来要开始双链表的讲解了,双链表比单链表要复杂一些,不过确实要比单链表更好进行实现!下面紧跟小编的步伐,开启今天的双链表之旅! 目录 1.概念和结构…...

银行项目利润问题(贪心思想)
import java.util.Comparator; import java.util.PriorityQueue;public class test32 {//输入正数数组costs、正数数组profits、正数K、正数M//costs[i]表示i号项目花费,profits[i]表示i号项目在扣除花费后还挣的钱//K表示有多少项目//M表示初始资金//每做完一个项目…...

SQLite
SQLite Insert 插入 语句 方式1: INSERT INTO TABLE_NAME [(column1, column2, column3,...columnN)] VALUES (value1, value2, value3,...valueN); 方式2: INSERT INTO TABLE_NAME VALUES (value1,value2,value3,...valueN); (如果要…...

浅谈 Mybatis 框架
文章目录 一、什么是MyBatis?1.2、JDBC 二、使用Mybatis2.1、配置MyBatis开发环境2.1.1、配置连接字符串2.1.2、配置MyBatis中的XML路径 2.2、使用MyBatis模式和语法操作数据库 三、使用 Mybatis 进行增删改查操作的要点3.1、ResultMap的用法 四、Mybatis操作难点4.1、#{ } 和…...

【星海随笔】OSPF协议
OSPF OSPF 可在单一自治系统(Autonomous System, AS)内决策路由。OSPF 是目前内部网关协议中使用最为广泛、性能最优的一个动态路由协议。 (1) OSPF 的特点。可适应大规模的网,路由变化收敛速度块,无路由自环,支持变…...

Vue 使用elementUI-plus el-calendar加 公历转农历 是否节假日 等
效果图: 1. 使用到自定文件 calendar.js /*** 1900-2100区间内的公历、农历互转* charset UTF-8* Author Jea杨(JJonlineJJonline.Cn)* Time 2014-7-21* Time 2016-8-13 Fixed 2033hex、Attribution Annals* Time 2016-9-25 Fixed lunar LeapMonth Param…...

SQL-锁
一.锁的介绍 锁是计算机协调多个进程或线程并发访问一资源的机制。在数据中,除传统的计算资源(CPU,RAM,I/O)的争用以外,数据也是一种供许多用户共享的资源。如何保证数据并发访问的一致性,有效性是所有数据库必须解决的一个问题,锁冲突也是影响数据库并发访问性能的一个重要因…...

索引小tips
一、优化原则 关于创建索引: 1. 【强制】InnoDB表必须主键为id int/bigint auto_increment,且主键值禁⽌被更新 。 2. 【强制】InnoDB和MyISAM存储引擎表,索引类型必须为 BTREE 。 3. 【建议】主键的名称以 pk 开头,唯⼀键以…...

2024年【中级消防设施操作员(考前冲刺)】报名考试及中级消防设施操作员(考前冲刺)免费试题
题库来源:安全生产模拟考试一点通公众号小程序 中级消防设施操作员(考前冲刺)报名考试是安全生产模拟考试一点通生成的,中级消防设施操作员(考前冲刺)证模拟考试题库是根据中级消防设施操作员(…...

数据结构:栈(含源码)
目录 一、栈的概念和结构 二、栈的实现 2.1 头文件 2.2 各个功能的实现 初始化栈 入栈 出栈 获取栈顶元素和栈中有效个数 判断栈是否为空 栈的销毁 2.3 测试 完整源码 一、栈的概念和结构 栈:一种特殊的线性表,其只允许在固定的一端进行插入和…...
如何使用Markdown编辑器
欢迎使用Markdown编辑器 你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。 新的改变 我们对Markdown编辑器进行了一些功能拓展与语法支持&#x…...

当代最火的哲学家颜廷利:全球公认十个最厉害的思想家之一
颜廷利书法特点和艺术成就:全球公认十个最厉害的思想家之一,颜廷利教授是一位杰出的书法家,他的书法作品不仅体现了中国传统文化,而且在国内外享有高度评价,对当代书法艺术产生了深远的影响。在中国十大顶级哲学家排行榜上,当今世界最重要的思想家颜廷利教授的书…...