es6 fetch

news2025/3/26 11:05:03

对比XHR

在这里插入图片描述

🛠️ fetch 所有配置项

fetch(url, {
  // ========== 核心配置 ==========
  method: 'GET',           // HTTP 方法: GET, POST, PUT, DELETE, PATCH, HEAD, OPTIONS
  headers: {               // 请求头(支持 Headers 对象或普通对象)
    'Content-Type': 'application/json', // 常用 Content-Type 值:
                                        // - application/x-www-form-urlencoded  默认表单提交(键值对)
                                        // - application/json  JSON 数据
                                        // - application/octet-stream  任意二进制数据(如文件下载)
                                        // - multipart/form-data 表单文件上传(支持二进制)
                                        // - text/plain  纯文本(无格式)
    'Authorization': 'Bearer token',    // 身份验证
    'Accept': 'application/json',        // 指定响应格式
    'X-Custom-Header': 'value'          // 自定义头
  },
  body: null,              // 请求体数据,支持以下类型:
                          // - String(JSON 字符串)
                          // - FormData(表单/文件上传)
                          // - URLSearchParams(查询参数,自动设置 Content-Type)
                          // - Blob/BufferSource(二进制数据)
                          // - ReadableStream(流式数据,实验性)

  // ========== 网络策略配置 ==========
  mode: 'cors',           // 请求模式,可选值:
                         // - cors: 允许跨域(需服务器返回 CORS 头)
                         // - no-cors: 禁止跨域(响应不可读,仅用于简单请求)
                         // - same-origin: 仅同源请求
  credentials: 'same-origin', // Cookie 策略,可选值:
                             // - omit: 不发送 Cookie(默认)
                             // - same-origin: 同源时发送
                             // - include: 跨域也发送(需服务器允许 credentials)
  cache: 'default',       // 缓存策略,可选值:
                         // - default: 遵循浏览器缓存
                         // - no-store: 禁用缓存
                         // - reload: 强制绕过缓存
                         // - no-cache: 使用缓存但重新验证
                         // - force-cache: 优先使用过期缓存
  redirect: 'follow',     // 重定向处理,可选值:
                         // - follow: 自动重定向(默认)
                         // - error: 重定向时报错
                         // - manual: 手动处理(通过 response.redirected 判断)
  
  // ========== 来源与安全 ==========
  referrer: 'about:client', // 来源页地址,可选值:
                           // - "about:client": 隐藏来源(默认)
                           // - "no-referrer": 不发送 Referer 头
                           // - URL: 指定来源地址
  referrerPolicy: 'no-referrer-when-downgrade', // 来源策略,控制 Referer 头发送规则
                                              // 常见值: no-referrer, origin, strict-origin
  integrity: 'sha256-abc123', // 子资源完整性校验(SRI),用于验证资源是否被篡改
                            // 格式: '哈希算法-哈希值'(如 sha256-xxxx)

  // ========== 高级控制 ==========
  keepalive: false,       // 是否允许请求在页面卸载后继续发送(用于埋点/日志)
  signal: null,           // 绑定 AbortSignal 对象以取消请求(结合 AbortController)
  priority: 'auto',       // 请求优先级(实验性),可选值: high, low, auto
  window: null            // 必须设为 null(保留字段,用于未来扩展)
});

Content-Type

告知接收方(如服务器或浏览器)​传输的数据是什么类型,例如:JSON、HTML、表单、图片等。

。。。


⚠️ 使用fetch 注意事项

  1. ​HTTP 错误不会触发 catch
    问题:fetch 仅在网络故障(如无法连接)时 reject,但 HTTP 错误(如 404、500)会正常返回响应。

  2. 默认不携带 Cookie
    ​问题:跨域请求默认不发送 Cookie,可能导致身份验证失败。
    ​解决:设置 credentials: ‘include’:

  3. 请求体需要手动序列化
    ​问题:发送 JSON 数据时需手动调用 JSON.stringify(),而 axios 等库会自动处理。

  4. 响应体只能读取一次
    ​问题:调用 response.json() 或 response.text() 后,响应体会被标记为已使用,再次读取会报错。
    ​解决:使用 response.clone() 克隆响应

⚠️ 缺陷

  1. ​不支持同步请求
    ​问题:fetch 只有异步模式,无法像 XMLHttpRequest 一样执行同步操作。
    ​解决:使用 async/await 模拟同步逻辑
async function fetchData() {
  const response = await fetch(url);
  const data = await response.json();
  return data;
}
  1. ​取消请求依赖 AbortController
    ​问题:取消请求需要额外引入 AbortController,不如 XMLHttpRequest.abort() 直接。
    ​解决:
const controller = new AbortController();
fetch(url, { signal: controller.signal });
controller.abort(); // 取消请求
  1. ​缺乏上传/下载进度监控
    ​问题:fetch 无法原生监控上传或下载进度,而 XMLHttpRequest 支持。
    ​解决:通过流式处理或自定义逻辑间接实现:
const response = await fetch(url);
const reader = response.body.getReader();
let received = 0;
while (true) {
  const { done, value } = await reader.read();
  if (done) break;
  received += value.length;
  console.log(`Received ${received} bytes`);
}

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

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

相关文章

智能汽车图像及视频处理方案,支持视频星轨拍摄能力

美摄科技作为智能汽车图像及视频处理领域的先行者,正以革新性的技术引领着行业的未来发展。美摄科技智能汽车图像及视频处理方案,一个集高效性、智能化、画质增强于一体的创新解决方案,旨在重塑智能汽车图像画质的新标准,并支持前…

C盘急救实录:从爆红到畅快

极速救援通道(懒人专享) 老规矩,先上王炸方案!”小番茄C盘清理器”直达链接:https://cclean-cdn.xkbrowser.com/cleanmaster/FanQieClean_13046_st.exe 这个神器有三绝: 智能扫描引擎:能识别23…

UART转APB模块ModelSim仿真

一、简介 之前介绍过一个UART转AHB模块,这个代码的框架有个好处,就是FPGA内总线接口比较容易修改成其他总线接口。下图是UART转AHB模块中子模块uart_ahb_mst的框图,主要有三个状态机: (1) UART_RX_FSM将接收…

Cesium 自定义路径导航材质

cesium 自定义路径导航纹理图片随便更换,UI 提供设计图片即可达到效果; 打开小马的weix 关注下 搜索“技术链” 回复关键词《《路径》》获取原始代码; 拿到就能用轻松解决!帮忙点个关注吧!

【江协科技STM32】BKP备寄存器RTC实时时钟(学习笔记)

BKP备寄存器 BKP简介 BKP(Backup Registers)备份寄存器BKP可用于存储用户应用程序数据。当VDD(2.0~3.6V)电源被切断,他们仍然由VBAT(1.8~3.6V)维持供电。当系统在待机模式下被唤醒&#xff0…

卷积神经网络 - 参数学习

本文我们通过两个简化的例子,展示如何从前向传播、损失计算,到反向传播推导梯度,再到参数更新,完整地描述卷积层的参数学习过程。 一、例子一 我们构造一个非常简单的卷积神经网络,其结构仅包含一个卷积层和一个输出…

亮数据爬取API爬取亚马逊电商平台实战教程

前言 在当今数据驱动的商业环境中,企业需要快速、精准地获取互联网上的公开数据以支持市场分析、竞品调研和用户行为研究。然而,传统的手动网页爬取方式面临着诸多挑战:IP封锁、验证码干扰、网站结构频繁变更,以及高昂的运维成本…

[CLS] Token 在 ViT(Vision Transformer)中的作用与实现

[CLS] Token 在 ViT(Vision Transformer)中的作用与实现 1. 什么是 [CLS] Token? [CLS](classification token)是Transformer模型中一个可学习的嵌入向量,最初在 BERT(Bidirectional Encoder …

基于网启PXE服务器的批量定制系统平台

项目概述 1.需求 公司新购了一批服务器和台式机,需要为台式机和服务器安装系统,一部分需要安装国产OpenEuler,一部分要求安装CentOS 7.9,同时也要满足定制化需求,即按要求分区安装相应软件。 2.使用开源软件 &…

在本地Windows机器加载大模型并生成内容

本篇演示在本地机器下载和加载大模型并获取AI产生的内容。简单起见,使用的大模型是Qwen2.5-0.5B-Instruct,整个模型的所有文件不到1G。 Qwen2.5-0.5B-Instruct 是阿里巴巴云 QWen 团队基于 Transformer 架构开发的轻量级指令调优语言模型,专…

热门面试题第14天|Leetcode 513找树左下角的值 112 113 路径总和 105 106 从中序与后序遍历序列构造二叉树 (及其扩展形式)以一敌二

找树左下角的值 本题递归偏难,反而迭代简单属于模板题, 两种方法掌握一下 题目链接/文章讲解/视频讲解:https://programmercarl.com/0513.%E6%89%BE%E6%A0%91%E5%B7%A6%E4%B8%8B%E8%A7%92%E7%9A%84%E5%80%BC.html 我们来分析一下题目&#…

【计算机网络】-计算机网络期末复习题复习资料

一、计算机网络体系结构(800字) 1. OSI参考模型 七层结构:物理层→数据链路层→网络层→传输层→会话层→表示层→应用层 各层核心功能: 物理层:比特流传输(如RJ45、光纤接口) 数据链路层&…

批归一化(Batch Normalization)与层归一化(Layer Normalization)的区别与联系

文章目录 一、Batch normalization 理论与应用1. 理论解释2. 数值例子 二、Layer normalization 理论与应用1. 理论解释2. 数值例子 三、Layer Normalization 和 Batch Normalization 的区别四、《Transformers without Normalization》笔记 一、Batch normalization 理论与应用…

12届蓝桥杯—货物摆放

货物摆放 题目描述 小蓝有一个超大的仓库,可以摆放很多货物。 现在,小蓝有 nn 箱货物要摆放在仓库,每箱货物都是规则的正方体。小蓝规定了长、宽、高三个互相垂直的方向,每箱货物的边都必须严格平行于长、宽、高。 小蓝希望所…

c++进阶--哈希表的实现

大家好,今天我们来学习ubordered_set和unordered_map的底层哈希表。 目录 哈希表实现 1. 哈希概念 1.1 直接定址法 1.2 哈希冲突 1.3 负载因⼦ 1.4 将关键字转为整数 1.5 哈希函数 下面我们介绍几种哈希函数:1.5.1 除法散列法/除留余数法 1.…

颠覆传统:SaaS 品牌如何通过 SEO 策略引爆市场!

SaaS 商业模式提供了令人难以置信的可扩展性和盈利能力——但前提是与正确的营销增长策略相结合。 SaaS 品牌知道,托管基于云的应用程序的成本会随着用户量的增加而降低,因此必须专注于订阅者的快速增长,以保持竞争力并降低成本。 许多 CMO…

特殊行车记录仪DAT视频丢失的恢复方法

行车记录仪是一种常见的车载记录仪,和常见的“小巧玲珑”的行车记录仪不同,一些特种车辆使用的记录仪的外观可以用“笨重”来形容。下边我们来看看特种车载行车记录仪删除文件后的恢复方法。 故障存储: 120GB存储设备/文件系统:exFAT /簇大小:128KB 故…

数据库中不存在该字段

mybatisplus 定义的类中某些字段是数据库里面没有的,我们可用tablefield(existfalse)来注解,演示如下:

吾爱出品,文件分类助手,高效管理您的 PC 资源库

在日常使用电脑的过程中,文件杂乱无章常常让人感到困扰。无论是桌面堆积如山的快捷方式,还是硬盘中混乱的音频、视频、文档等资源,都急需一种高效的整理方法。文件分类助手应运而生,它是一款文件管理工具,能够快速、智…

关于瑞芯微开发工具(RKDevTool)刷机下载Boot失败原因的研究

昨天发了文章《网心云OEC/OEC-turbo刷机问题——刷机教程、救砖方法、技术要点及下载boot失败异常解决尝试》,其中有关于刷机各种问题的一些解决方法。 网心云OEC/OEC-turbo刷机问题——刷机教程、救砖方法、技术要点及下载boot失败异常解决尝试-CSDN博客文章浏览阅…