F12 网络请求类型:Fetch与XHR的区别

F12 网络请求类型:Fetch与XHR的区别

引言

在Web开发中,浏览器的F12开发者工具是调试网络请求的重要工具。通过F12,我们可以查看各种类型的网络请求,包括fetchXMLHttpRequest(XHR)。这两种技术都用于在浏览器中发起网络请求,但它们之间存在一些关键的差异。

基础知识
  • F12开发者工具:大多数现代浏览器都提供了开发者工具,可以通过按F12键或右键点击页面元素选择“检查”来打开。它允许开发者查看网络请求、调试JavaScript、编辑CSS等。
Fetch API
  • 定义:Fetch API是一个现代的、基于Promise的网络请求接口,用于替代XMLHttpRequest。
  • 特点
    • 基于Promise,使得异步请求更加容易管理和编写。
    • 提供了更灵活的请求和响应处理方式。
    • 支持最新的Web标准,如CORS(跨源资源共享)。
XMLHttpRequest (XHR)
  • 定义:XHR是一个较旧的API,用于在浏览器中发起网络请求。它是Fetch API出现之前的标准。
  • 特点
    • 基于事件的模型,使用onreadystatechange事件处理请求状态变化。
    • 请求和响应处理较为复杂,需要手动设置请求头和解析响应。
    • 兼容性好,支持较旧的浏览器。
示例演示
  • Fetch API请求示例
    fetch('https://api.example.com/data').then(response => response.json()).then(data => console.log(data)).catch(error => console.error('Error:', error));
    
  • XMLHttpRequest请求示例
    var xhr = new XMLHttpRequest();
    xhr.open('GET', 'https://api.example.com/data');
    xhr.onreadystatechange = function() {if (xhr.readyState === 4 && xhr.status === 200) {console.log(JSON.parse(xhr.responseText));}
    };
    xhr.send();
    
实际应用
  • Fetch API:适用于需要处理JSON数据、支持Promise的场景,以及现代Web应用开发。
  • XMLHttpRequest:适用于需要兼容旧浏览器的场景,或者在Fetch API不可用时作为备选方案。
深入与最佳实践
  • Fetch API
    • 支持流式传输,可以处理大文件上传和下载。
    • 可以取消请求,适合处理复杂的用户交互。
  • XMLHttpRequest
    • 对于简单的请求,XHR可能更简单直接。
    • 由于是基于事件的,可能在某些情况下更易于理解和使用。
Fetch API 深入探讨
  • 跨域请求:Fetch支持CORS,可以简化跨域请求的处理。使用fetch发起跨域请求时,浏览器会自动携带CORS相关的头信息。
    fetch('https://api.example.com/data', {headers: {'Content-Type': 'application/json'}
    })
    .then(response => response.json())
    .then(data => console.log(data))
    .catch(error => console.error('Fetch Error:', error));
    
  • 请求超时:Fetch本身不支持超时设置,但可以通过AbortController实现。
    const controller = new AbortController();
    const signal = controller.signal;fetch('https://api.example.com/data', { signal })
    .then(response => response.json())
    .then(data => console.log(data))
    .catch(error => {if (error.name === 'AbortError') {console.log('Fetch aborted');} else {console.error('Fetch Error:', error);}
    });// 设置超时
    setTimeout(() => controller.abort(), 5000); // 5秒后中止请求
    
XMLHttpRequest (XHR) 深入探讨
  • 进度事件:XHR允许监听progress事件来跟踪文件上传或下载的进度。
    var xhr = new XMLHttpRequest();
    xhr.open('GET', 'https://api.example.com/largefile');xhr.onprogress = function(event) {if (event.lengthComputable) {console.log(`Received ${event.loaded} of ${event.total} bytes`);}
    };xhr.onload = function() {if (xhr.status === 200) {console.log('File received:', xhr.responseText);}
    };xhr.send();
    
  • 同步请求:XHR支持同步请求,但出于性能考虑,通常不推荐使用。
    var xhr = new XMLHttpRequest();
    xhr.open('GET', 'https://api.example.com/data', false); // 第三个参数为false表示同步请求
    xhr.send();if (xhr.status === 200) {console.log('Data:', xhr.responseText);
    } else {console.error('Request failed:', xhr.status);
    }
    
最佳实践
  • 错误处理:无论是使用Fetch还是XHR,始终要有健壮的错误处理机制。
    // Fetch错误处理
    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));// XHR错误处理
    var xhr = new XMLHttpRequest();
    xhr.open('GET', 'https://api.example.com/data');
    xhr.onerror = function() {console.error('Request error...');
    };
    xhr.send();
    
  • 安全措施:使用HTTPS协议,确保数据传输的安全性。
  • 请求头设置:根据需要设置适当的请求头,如认证令牌、内容类型等。
    // Fetch设置请求头
    fetch('https://api.example.com/data', {method: 'POST',headers: {'Content-Type': 'application/json','Authorization': 'Bearer your_token_here'},body: JSON.stringify({ key: 'value' })
    });// XHR设置请求头
    xhr.setRequestHeader('Content-Type', 'application/json');
    xhr.setRequestHeader('Authorization', 'Bearer your_token_here');
    
  • 性能优化:使用压缩、缓存和合理的请求策略来优化网络性能。
常见问题解答
  • 我应该使用Fetch还是XHR?
    • 如果你的目标是现代Web应用,并且需要处理JSON数据,推荐使用Fetch API。
    • 如果你需要支持旧浏览器,或者Fetch API不可用,可以考虑使用XHR。
结语

Fetch API和XMLHttpRequest都是浏览器中发起网络请求的重要工具。Fetch API以其现代化的接口和Promise支持,逐渐成为主流选择。然而,XHR仍然在某些特定场景下有其价值。

互动鼓励

分享你在实际开发中使用Fetch和XHR的经验,以及如何根据不同场景选择合适的技术。

技术准确

本文所提供的信息基于当前Web开发的最佳实践,并确保了技术细节的准确性。

学习资源

对于希望深入了解Fetch API和XMLHttpRequest的读者,推荐访问MDN Web Docs和相关技术博客,以获取更多学习资源和最佳实践。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/16506.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Linux——Linux服务管理

服务管理大作业要求: 基本拓扑如下: 按照要求完成基本的系统管理任务: 完成所有系统的主机名、网络配置; 本次作业共需要3台虚拟机,分别作为客户端、综合应用服务器、存储服务器。三台虚拟机操作系统均为CentOS-Stream…

5.2网安学习第五阶段第二周回顾(个人学习记录使用)

本周重点 ①HIDS的基本应用(suricata) ②Suricata的基本应用 ③Suricata的流量检测 ④Suricata的https流量检测 ⑤利用Elastic整合Suricata日志 ⑥利用Wazuh对Suricata主动响应 本周主要内容 ①HIDS的基本应用(suricata) 1、NIDS 1、定义:网络入侵检测系统…

算法简单笔记

本人大二下学期报了中国大学生计算机设计大赛、珠澳计算机设计大赛、区块链软件设计大赛、蓝桥杯......然后一直准备着设计大赛的比赛,根本没空管蓝桥杯,就省考前准备了一星期,感觉是没有希望了,但是很莫名其妙的就拿了蓝桥杯Java…

悲痛都会过去,唯有当下值得珍惜

在生活的长河中,我们都会经历各种各样的悲痛与挫折,无论是来自原生家庭的困扰,婚姻中的曲折,还是小时候的创伤、男女关系中的纠葛、校园时期的霸凌。然而,当我们回首过去,曾经以为无法逾越的痛苦&#xff0…

通过css实现------简单边框流动特效

效果展示 代码部分 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" content"widthdevice…

C++学习/复习5--构造函数与初始化/static成员/友元/内部类/匿名对象/编译器的拷贝构造优化

一、本章概要 二、再谈构造函数 1.构造体赋初值与初始化 2.初始化列表与初始化 2.1定义 2.2注意事项与举例 3.explicit关键字与构造函数 3.1隐式类型转换 也叫做自动类型转换 这种转换通常是从存储范围小的类型到存储范围大的类型&#xff0c;或者是从低精度的数值类型到高…

简述vue-loader是什么?使用它的用途有哪些

vue-loader是一个webpack的加载器(loader)&#xff0c;主要用于将Vue组件的单文件(.vue文件)转换为JavaScript模块。使用vue-loader的主要用途包括&#xff1a; 解析.vue文件&#xff1a;vue-loader能够解析.vue文件中的模板、样式和脚本&#xff0c;并将它们分离出来进行处理…

python爬虫学习(1)——初识爬虫

520那天我向心仪的女孩要微信&#xff1a;“女神&#xff0c;能给我你的微信号吗&#xff1f;” 女神&#xff1a;“爬&#xff01;&#xff01;&#xff01;&#xff01;” 从那天开始&#xff0c;我就决定要学好爬虫&#xff0c;爬到女神微信号&#xff01;&#xff01;&…

引入安全生产培训云平台,实现“人人讲安全、个个会应急”

引入安全生产培训云平台&#xff0c;旨在全面提升企业及员工的安全意识与应急处理能力&#xff0c;通过数字化手段实现“人人讲安全、个个会应急”的目标。这一平台的构建和应用&#xff0c;不仅促进了安全知识的普及&#xff0c;还极大提高了培训的效率与效果。以下是该平台几…

python 匿名函数 lambda

匿名函数 可以不使用def语句去定义&#xff0c;可以写到简单的表达式 语法结构 lambda 参数&#xff1a;表达式 简单使用 可以写推导式&#xff0c;三目运算符&#xff0c;但是不可以写x1 result lambda i, j: i*jprint(result(2, 3))# 输出 6 lambda运用filter list1 [3…

驱动开发之字符设备开发

1.概念 字符设备是 Linux 驱动中最基本的一类设备驱动&#xff0c;字符设备就是一个一个字节&#xff0c;按照字节 流进行读写操作的设备&#xff0c;读写数据是分先后顺序的。比如我们最常见的点灯、按键、IIC、SPI&#xff0c; LCD 等等都是字符设备&#xff0c;这些设备的驱…

实验室课程|基于SprinBoot+vue的实验室课程管理系统(源码+数据库+文档)

实验室课程管理系统 目录 基于SprinBootvue的实验室课程管理系统 一、前言 二、系统设计 三、系统功能设计 1管理员功能模块 2学生功能模块 3教师功能模块 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 博主介…

elementui中 表格使用树形数据且固定一列时展开子集移入时背景色不全问题(父级和子级所展示的字段是不一样的时候)

原来的效果 修改后实现效果 解决- 需要修改elementui的依赖包中lib/element-ui.common.js中的源码 将js中此处代码改完下面的代码 watch: {// dont trigger getter of currentRow in getCellClass. see https://jsfiddle.net/oe2b4hqt/// update DOM manually. see https:/…

幽默的力量

1.以对方的发型、服饰发生变化为借囗&#xff0c;夸赞对方一番。这是在想不起对方姓名时一个为自己尴尬解围的好方法。例如&#xff0c;“哎呀&#xff0c;原来是你呀&#xff01;真对不住&#xff0c;没能马上想起来。不过你不能怨我&#xff0c;因为几个月的时间&#xff0c;…

Arrays.sort 和 Collections.sort 实现原理和区别?

Collection和Collections区别&#xff1a; java.util.Collection 是一个集合接口。它提供了对集合对象进行基本操作的通用接口方法。 java.util.Collections 是针对集合类的一个帮助类&#xff0c;他提供一系列静态方法实现对各种集合的搜索、排序、线程安全等操作。 然后还…

Oracle实践|内置函数之数学型函数

&#x1f4eb; 作者简介&#xff1a;「六月暴雪飞梨花」&#xff0c;专注于研究Java&#xff0c;就职于科技型公司后端工程师 &#x1f3c6; 近期荣誉&#xff1a;华为云云享专家、阿里云专家博主、腾讯云优秀创作者、ACDU成员 &#x1f525; 三连支持&#xff1a;欢迎 ❤️关注…

【Linux安全】Firewalld防火墙基础

目录 一、Firewalld概述 二、Firewalld和iptables的关系 三、Firewalld网络区域 1、firewalld防火墙预定义了9个区域: 2、firewalld 数据包处理原则 3、firewalld数据处理流程 4、firewalld检查数据包的源地址的规则 四、Firewalld防火墙的配置方法 1、firewalld 命令…

SpringBoot项目热部署-解决html修改后需要重启项目的问题

前言&#xff1a;启动热部署之后修改html无需再次重启项目&#xff0c;每次都要重新重启项目 2022IDEA以下版本 1、打开file->Settings->Compiler,勾选Build project automatically 2、按住ctrlshiftalt/ 选Registry进去吧app.running的勾打上、 2022IDEA及以上

NVIDIA Orin/Jetson 平台+数字同轴GMSL 车载AI视觉方案,应用于车载,机器人等领域

专注于成像和视觉技术于近期正式发布了可适配NVIDIA DRIVE AGX Orin平台的一系列摄像头产品&#xff0c;该产品是自主开发的数字同轴GMSL2摄像头模组&#xff0c;可满足智能汽车的高质量成像需求。 目前&#xff0c;推出可适配于NVIDIA DRIVE AGX Orin平台的摄像头产品一共有11…

Modular military character

角色具有31个模块化骨架网格,每个模块具有多个蒙皮: 3个头(4skins) 3件衬衫(9skins) 3条裤子(9skins) 3只靴子(9skins) 7件战术背心(3skins) 4只手和手臂(2skins) 3顶帽子和头盔(9skins) 2个背包(3skins) 3支步枪(3skins) 模块允许您组装超过200万个不同的…