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

Fetch API 与 XMLHttpRequest:深入剖析异步请求的利器

Hi,我是布兰妮甜 !在现代 Web 开发中,异步通信是实现动态和交互式用户体验的基石。XMLHttpRequest (XHR) 作为老牌劲旅,曾一度统治着这一领域。然而,随着 Fetch API 的横空出世,开发者们迎来了一个更现代、更强大的工具。本文将深入剖析 Fetch APIXMLHttpRequest,从基本概念到高级用法,为您呈现一场异步请求的盛宴。


文章目录

    • 一、XMLHttpRequest:功勋元老
    • 二、Fetch API:新星崛起
    • 三、Fetch API 与 XMLHttpRequest:详细对比
    • 四、高级用法与最佳实践
    • 五、总结


一、XMLHttpRequest:功勋元老

XMLHttpRequest 是一个 JavaScript 对象,它允许网页与服务器进行异步通信。自诞生以来,XHR 便成为 Ajax 技术的核心,为 Web 2.0 的发展立下了汗马功劳。

1.1 核心特性

  • 异步通信: XHR 的最大特点就是异步,它可以在不刷新页面的情况下与服务器交换数据,从而实现页面的局部更新。

  • 灵活控制: XHR 提供了丰富的 API,允许开发者对请求和响应进行精细的控制,例如设置请求头、监听状态变化、获取响应数据等。

1.2 代码示例

const xhr = new XMLHttpRequest();
xhr.open('GET', 'https://api.example.com/data');
xhr.onreadystatechange = function() {if (xhr.readyState === 4 && xhr.status === 200) {console.log(xhr.responseText);}
};
xhr.send();

1.3 优缺点分析

  • 优点

    • 广泛支持: XHR 被所有主流浏览器支持,兼容性极佳。

    • 功能强大: XHR 提供了丰富的功能和细粒度的控制,可以满足各种复杂场景的需求。

  • 缺点

    • API 复杂: XHR 的 API 设计较为复杂,学习和使用成本较高。

    • 回调地狱: XHR 依赖于回调函数处理异步操作,容易导致代码嵌套过深,难以维护。

    • 缺乏 Promise 支持: XHR 本身不支持 Promise,需要借助第三方库或手动封装。

代码示例

const xhr = new XMLHttpRequest();
xhr.open('GET', 'https://api.example.com/data');
xhr.onload = function() {if (xhr.status === 200) {console.log(xhr.responseText);} else {console.error('Error:', xhr.statusText);}
};
xhr.onerror = function() {console.error('Request failed');
};
xhr.send();

二、Fetch API:新星崛起

Fetch API 是 XMLHttpRequest 的现代替代品,它提供了更简洁、更强大的方式来执行异步请求。Fetch API 基于 Promise,使得异步代码更加清晰易读。

2.1 核心特性

  • 基于 Promise: Fetch API 使用 Promise 处理异步操作,避免了回调地狱,使代码更加简洁和易于维护。

  • 简洁的 API: Fetch API 的 API 设计更加简洁直观,易于学习和使用。

  • 更强大的功能: Fetch API 提供了比 XHR 更强大的功能,例如对请求和响应对象的更细粒度控制、对流的支持以及更灵活的错误处理。

2.2 代码示例

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('Error:', error));

2.3 优缺点分析

  • 优点

    • 简洁易用: Fetch API 的 API 设计简洁直观,学习和使用成本低。

    • 基于 Promise: 使用 Promise 处理异步操作,避免了回调地狱,使代码更加清晰易读。

    • 功能强大: 提供了比 XHR 更强大的功能,例如对流的支持、更灵活的错误处理等。

  • 缺点

    • 浏览器兼容性: Fetch API 在现代浏览器中得到广泛支持,但在一些较旧的浏览器中可能无法使用。

    • 功能限制: 与 XHR 相比,Fetch API 缺少一些功能,例如取消请求和监控进度。

三、Fetch API 与 XMLHttpRequest:详细对比

特性Fetch APIXMLHttpRequest
浏览器支持现代浏览器所有主流浏览器,包括较旧的浏览器
API 设计简洁、直观复杂、笨拙
异步处理基于 Promise基于回调函数
请求和响应对象更细粒度的控制控制较少
流支持支持不支持
错误处理更灵活较不灵活
取消请求不支持支持
监控进度不支持支持

四、高级用法与最佳实践

4.1 Fetch API 的高级用法

  • 自定义请求头: 使用 Headers 对象设置自定义请求头。

  • 发送表单数据: 使用 FormData 对象发送表单数据。

  • 处理二进制数据: 使用 ArrayBufferBlob 对象处理二进制数据。

  • 超时控制: 使用 AbortController 实现请求超时控制。

4.2 XMLHttpRequest 的高级用法

  • 监控请求进度: 使用 onprogress 事件监控请求进度。

  • 上传文件: 使用 FormData 对象上传文件。

  • 设置超时时间: 使用 timeout 属性设置请求超时时间。

  • 取消请求: 使用 abort() 方法取消请求。

4.3 最佳实践

  • 优先使用 Fetch API: 对于新项目,建议优先使用 Fetch API,除非您需要 XHR 提供的特定功能或需要支持较旧的浏览器。

  • 处理错误: 无论是使用 Fetch API 还是 XHR,都要注意处理错误,例如网络错误、服务器错误等。

  • 使用 Promise: 尽量使用 Promise 处理异步操作,避免回调地狱。

  • 代码复用: 将常用的请求逻辑封装成函数或模块,提高代码复用率。

五、总结

Fetch API 和 XMLHttpRequest 都是用于在 Web 应用程序中进行异步通信的强大工具。虽然 XHR 已经存在了很长时间并且被广泛支持,但 Fetch API 提供了一个更现代、更强大的替代方案,具有更简洁的 API 和更强大的功能。对于新项目,建议使用 Fetch API,除非您需要 XHR 提供的特定功能或需要支持较旧的浏览器。

随着 Web 技术的不断发展,Fetch API 正在成为异步请求的标准。它不断获得新的功能和改进,而 XHR 则逐渐被淘汰。因此,建议开发者们尽快熟悉 Fetch API 并将其用于新的项目中。

相关文章:

Fetch API 与 XMLHttpRequest:深入剖析异步请求的利器

Hi,我是布兰妮甜 !在现代 Web 开发中,异步通信是实现动态和交互式用户体验的基石。XMLHttpRequest (XHR) 作为老牌劲旅,曾一度统治着这一领域。然而,随着 Fetch API 的横空出世,开发者们迎来了一个更现代、…...

如何生成traceid以及可视化展示

根据你的需求,以下是一些可以生成唯一 traceId 并用于分布式链路追踪的工具和项目,这些项目支持生成唯一的 traceId,并将其用于日志记录和分布式追踪: 1. OpenTelemetry OpenTelemetry 是一个开源的观测框架,支持生成…...

【LeetCode541】反转字符串

题目描述 给定一个字符串 s 和一个整数 k,从字符串开头算起,每计数至 2k 个字符,就反转这 2k 字符中的前 k 个字符。 如果剩余字符少于 k 个,则将剩余字符全部反转。 如果剩余字符小于 2k 但大于或等于 k 个,则反转前…...

DeepSeek、微信、硅基流动、纳米搜索、秘塔搜索……十种不同方法实现DeepSeek使用自由

为了让大家实现 DeepSeek 使用自由,今天分享 10 个畅用 DeepSeek 的平台。 一、官方满血版:DeepSeek官网与APP 首推,肯定是 DeepSeek 的官网和 APP,可以使用满血版 R1 和 V3 模型,以及联网功能。 网址: htt…...

C++:pthread线程分离和线程属性

在 C 的多线程编程中,pthread 库提供了强大的功能来管理线程。其中,线程分离和线程属性是两个重要的概念,它们对于优化线程的行为和资源管理有着关键作用。 线程分离 1.1 什么是线程分离 在 pthread 库中,线程有两种状态&#…...

Orange 开源项目 - 集成阿里云大模型

1 阿里云的大模型服务平台百炼 阿里云的大模型服务平台百炼是一站式的大模型开发及应用构建平台。不论是开发者还是业务人员,都能深入参与大模型应用的设计和构建。您可以通过简单的界面操作,在5分钟内开发出一款大模型应用,或在几小时内训练…...

Docker 搭建 MySQL 数据库

Docker 搭建 MySQL 数据库 前言一、准备工作二、设置 MySQL 容器的目录结构三、配置 MySQL 容器四、自定义 MySQL 配置五、端口配置:Host 网络模式 vs Port 映射模式六、检查 MySQL 容器状态七、连接到 MySQL 容器八、备份与恢复总结 前言 在本篇文章中&#xff0c…...

使用 Docker 部署 Flask 应用

使用 Docker 部署 Flask 应用 一、引言 在现代软件开发中,应用的部署和环境管理是至关重要的环节。传统的部署方式常常会遇到 “在我机器上能运行,在你机器上不行” 的问题,而 Docker 的出现很好地解决了这个痛点。Docker 是一个用于开发、部署和运行应用程序的开放平台,…...

公开整理-最新中国城市统计NJExcel+PDF版本(1985-2024年)

数据简介:《中国城市统计NJ》从1985年开始,本NJ内容共分四个部分:第一部分是全国城市行政区划,列有不同区域、不同级别的城市分布情况;第二、三部分分别是地级以上城市统计资料和县级城市统计资料,具体包括人口、劳动力及土地资源、综合经济、工业、交通…...

python绘图之swarmplot分布散点图

swarmplot 是 Seaborn 提供的一种用于展示分类数据分布的散点图。它的主要作用是将数据点按照分类变量(通常是离散变量)进行分组,并在每个分类中以一种非重叠的方式展示数据点的位置。这种可视化方式可以帮助我们直观地理解数据在不同分类下的…...

KubeSphere平台安装

KubeSphere简介 KubeSphere 是一款功能强大的容器管理平台,以下是其简介: 1)基本信息 开源项目:基于 Apache-2.0 授权协议开源,由 Google Go、Groovy、HTML/CSS 和 Shell 等多种编程语言开发。基础架构:…...

Claude 3.7 Sonnet 泄露,Anthropic 最先进 AI 模型即将在 AWS Bedrock 上首次亮相

(图片:AWS) Anthropic 旗下先进的 AI 模型 Claude 3.7 Sonnet 似乎即将发布。业界预计,亚马逊可能会在2025年2月26日的活动中公布相关消息。泄露的信息表明,该模型将托管于 AWS Bedrock 平台,该平台以提供尖端 AI 模型访问而闻名…...

ONNX转RKNN的环境搭建和部署流程

将ONNX模型转换为RKNN模型的过程记录 工具准备 rknn-toolkit:https://github.com/rockchip-linux/rknn-toolkit rknn-toolkit2:https://github.com/airockchip/rknn-toolkit2 rknn_model_zoo:https://github.com/airockchip/rknn_model_zoo ultralytics_yolov8:https://github…...

解决鼠标唤醒关屏状态下的笔记本

以下是通过计划任务和PowerShell实现鼠标唤醒控制的全网独家解决方案,基于Windows事件触发机制,结合设备管理API实现精准控制,最终实现仅需通过win+l锁定屏幕,再关闭屏幕,既不会出现唤醒笔记问的问题: 一、技术原理深度解析 1. 事件触发机制 Windows安全子系统在锁屏/…...

MongoDB 复制(副本集)

MongoDB 复制(副本集) 引言 MongoDB是一个高性能、可扩展、易于使用的文档存储系统。它以JSON-like的文档存储结构,支持灵活的数据模型。在分布式系统中,为了提高数据可用性和系统稳定性,常常需要实现数据的备份和冗余。MongoDB提供了副本集…...

聊聊 FocusSearch/focus_mcp_sql:Text2SQL 的新玩法

聊聊 FocusSearch/focus_mcp_sql:Text2SQL 的新玩法 最近在 GitHub 上逛的时候,发现了一个挺有意思的项目——FocusSearch/focus_mcp_sql。作为一个对 Text2SQL 有点小研究的前端码农,我忍不住想和大家聊聊这个工具。它不像那些常见的基于大…...

Linux红帽:RHCSA认证知识讲解(二)配置网络与登录本地远程Linux主机

Linux红帽:RHCSA认证知识讲解(二)配置网络与登录本地远程Linux主机 前言一、使用命令行(nmcli 命令)配置网络,配置主机名第一步第二步修改主机名称 二、使用图形化界面(nmtui 命令)配…...

C#开发——ConcurrentDictionary集合

ConcurrentDictionary<TKey, TValue> 是 C# 中一个专为多线程场景设计的线程安全字典集合&#xff0c;位于 System.Collections.Concurrent 命名空间中。它允许多个线程同时对字典进行读写操作&#xff0c;而无需额外的同步措施。 一、集合特征 此集合有如下特征…...

深入浅出ES6:现代JavaScript的基石

ES6&#xff08;ECMAScript 2015&#xff09;是JavaScript语言的一次重大更新&#xff0c;引入了许多新特性&#xff0c;使JavaScript更加强大、优雅和易于维护。这些特性已经成为现代JavaScript开发的基石&#xff0c;掌握它们对于任何JavaScript开发者都至关重要。本文将深入…...

小型字符级语言模型的改进方向和策略

小型字符级语言模型的改进方向和策略 一、回顾小型字符级语言模型的处理流程 前文我们已经从零开始构建了一个小型字符级语言模型,那么如何改进和完善我们的模型呢?有哪些改进的方向?我们先回顾一下模型的流程: 图1 小型字符级语言模型的处理流程 (1)核心模块交互过程:…...

一周学会Flask3 Python Web开发-Jinja2模板访问对象

锋哥原创的Flask3 Python Web开发 Flask3视频教程&#xff1a; 2025版 Flask3 Python web开发 视频教程(无废话版) 玩命更新中~_哔哩哔哩_bilibili 如果渲染模板传的是对象&#xff0c;如果如何来访问呢&#xff1f; 我们看下下面示例&#xff1a; 定义一个Student类 cla…...

vue 3D 翻页效果

<template><view class"swipe-container" touchstart"onTouchStart" touchmove"onTouchMove" touchend"onTouchEnd"><view class"page">初始页</view></view> </template><script&g…...

JSONL 是什么格式

JSONL&#xff08;JSON Lines&#xff09;格式是一种简洁的文件格式&#xff0c;它将每一行作为一个独立的JSON对象&#xff0c;每个对象之间通过换行符分隔。JSONL常用于处理大规模数据&#xff0c;特别是在日志文件、机器学习数据集或数据流应用中。 示例 假设我们有以下3条…...

npm : 无法加载文件 E:\ProgramFiles\Nodejs\npm.ps1,因为在此系统上禁止运行脚本。

这个错误是因为 Windows 系统的 PowerShell 执行策略 限制了脚本的运行。默认情况下&#xff0c;PowerShell 的执行策略是 Restricted&#xff0c;即禁止运行任何脚本。以下是解决该问题的步骤&#xff1a; 1. 检查当前执行策略 打开 PowerShell&#xff08;管理员权限&#x…...

pycharm 调试 debug 进入 remote_sources

解决办法1&#xff1a; pycharm函数跳转到remote_sources中的文件中_pycharm修改remotesource包存放地址-CSDN博客 file->settings->project structure将项目文件夹设为"Sources"&#xff08;此时文件夹会变为蓝色&#xff09;。 解决方法2 Debug:使用Pychar…...

测试面试题:以一个登录窗口为例,设计一下登录界面测试的思路和方法

在测试登录窗口时,可以从 表单测试、 逻辑判断和 业务流程三个方面设计测试思路和方法。以下是一个详细的测试方案: 1. 表单测试 表单测试主要关注输入框、按钮等UI元素的正确性和用户体验。 测试点: 输入框测试 用户名和密码输入框是否正常显示。输入框是否支持预期的字符类…...

[特殊字符] 蓝桥杯 Java B 组 之最小生成树(Prim、Kruskal) 并查集应用

Day 3&#xff1a;最小生成树&#xff08;Prim、Kruskal&#xff09; & 并查集应用 &#x1f4d6; 一、最小生成树&#xff08;MST&#xff09;简介 最小生成树&#xff08;Minimum Spanning Tree, MST&#xff09; 是一个 无向连通图 的 最小代价子图&#xff0c;它包含 …...

【蓝桥杯】1.k倍区间

前缀和 #include <iostream> using namespace std; const int N100010; long long a[N]; int cnt[N]; int main(){int n, m;cnt[0] 1;cin >> n >> m;long long res 0;for(int i 1; i < n; i){scanf("%d", &a[i]);a[i] a[i-1];res cnt…...

机器人部分专业课

华东理工 人工智能与机器人导论 Introduction of Artificial Intelligence and Robots 必修 考查 0.5 8 8 0 1 16477012 程序设计基础 The Fundamentals of Programming 必修 考试 3 64 32 32 1 47450012 算法与数据结构 Algorithm and Data Structure 必修 考试 3 56 40 …...

SpringBoot两种方式接入DeepSeek

方式一&#xff1a;基于HttpClient 步骤 1&#xff1a;准备工作 获取 DeepSeek API 密钥&#xff1a;访问 DeepSeek 的开发者平台&#xff0c;注册并获取 API 密钥。 步骤 2&#xff1a;引入依赖 <dependency><groupId>org.springframework.boot</groupId&g…...