百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

JavaScript - Fetch API 完全手册

yuyutoo 2024-10-15 16:50 5 浏览 0 评论

如果您想从 API 加载数据,那么 fetch API 是在 JavaScript 中执行此操作的最佳方式。您不需要引入任何第三方库,就可以直接使用方便的fetch。

像上图所示,绝大多数浏览器已经原生支持Fetch,所以您可以放心使用。Node.js 对它的支持也正在路上,Fetch 已经作为 Node v17 中的实验性功能提供,你可以使用 node app.js --experimental-fetch 来开启它。

Fetch API 的基本使用

Fetch API 是基于Promise的,所以如果你不了解Promise, 最好先学习一下Promise。

调用 fetch API 的最简单方法是将 URL 传递给 fetch 函数。

这将返回一个包含响应数据的Promise。此响应数据包含状态属性以及将原始响应数据转换为 JSON、文本或其他格式的方法。

上面显示res.json() 是在我们的响应中调用 json() 方法,这个方法会返回另外一个 promise,该 promise 从我们的响应中解析 JSON 数据。

我们可以在后面的then方法中获取到最终需要的JSON数据对象。

如果您从 JSON api 获取数据,这就是大多数获取请求的样子。 我们首先获取 URL,然后将响应转换为 JSON,最后使用最终 .then 中的数据。

如果使用async/await语法,可能会更简单点。

Fetch 参数

这将涵盖您的一些 fetch 用途,但通常您需要传递其他选项来进行 fetch 配置。 fetch 函数采用第二个选项对象参数,其中包含大量潜在选项。

method

最常用的选项是方法选项。 此选项允许您设置要使用的 HTTP 动词(GET、POST、PUT、DELETE 等)。

body

如果您正在修改方法,那么您可能需要将数据与您的请求一起传递。 这就是 body 选项的用武之地。body 不接受对象,因此如果您想将 JSON 传递给您的 API,您必须首先将其转换为字符串。

headers

现在,执行上述操作可能看起来像是将 JSON 传递给 API 所需要做的一切,但这实际上是行不通的。 原因是您需要设置正确的标头来告诉您的 API 您正在发送 JSON 信息。 此标头选项允许您设置所需的任何 HTTP 标头。

上面这组代码是将 JSON 传递给 API 所需要做的一切。

signal

最后一个要说的的是信号选项。 这个选项接受一个 AbortSignal,它可以用来中止一个获取请求。

正如您从代码中看到的那样,这比其他选项要复杂一些。 首先你必须创建一个新的 AbortController 这个控制器有一个信号属性,这是你传递给signal选项的。 控制器还有一个 abort 方法,当调用该方法时,将使用相关信号中止获取请求。 这将导致 fetch Promise以 AbortError Reject异常。

这些选项应该是可以cover你90%左右的用例。具体还有其他一些不常用的可以去查看官网文档。

总结:

fetch API 是一个功能强大的工具,易于上手,它包含适用于每个可以想象的用例的许多高级选项。最重要的是,马上node.js就可以原生支持它,逻辑可以前后端共享,岂不美哉!

感谢阅读!

相关推荐

ETCD 故障恢复(etc常见故障)

概述Kubernetes集群外部ETCD节点故障,导致kube-apiserver无法启动。...

在Ubuntu 16.04 LTS服务器上安装FreeRADIUS和Daloradius的方法

FreeRADIUS为AAARadiusLinux下开源解决方案,DaloRadius为图形化web管理工具。...

如何排查服务器被黑客入侵的迹象(黑客 抓取服务器数据)

---排查服务器是否被黑客入侵需要系统性地检查多个关键点,以下是一份详细的排查指南,包含具体命令、工具和应对策略:---###**一、快速初步检查**####1.**检查异常登录记录**...

使用 Fail Ban 日志分析 SSH 攻击行为

通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...

《5 个实用技巧,提升你的服务器安全性,避免被黑客盯上!》

服务器的安全性至关重要,特别是在如今网络攻击频繁的情况下。如果你的服务器存在漏洞,黑客可能会利用这些漏洞进行攻击,甚至窃取数据。今天我们就来聊聊5个实用技巧,帮助你提升服务器的安全性,让你的系统更...

聊聊Spring AI Alibaba的YuQueDocumentReader

序本文主要研究一下SpringAIAlibaba的YuQueDocumentReaderYuQueDocumentReader...

Mac Docker环境,利用Canal实现MySQL同步ES

Canal的使用使用docker环境安装mysql、canal、elasticsearch,基于binlog利用canal实现mysql的数据同步到elasticsearch中,并在springboo...

RustDesk:开源远程控制工具的技术架构与全场景部署实战

一、开源远程控制领域的革新者1.1行业痛点与解决方案...

长安汽车一代CS75Plus2020款安装高德地图7.5

不用破解原车机,一代CS75Plus2020款,安装车机版高德地图7.5,有红绿灯读秒!废话不多讲,安装步骤如下:一、在拨号状态输入:在电话拨号界面,输入:*#518200#*(进入安卓设置界面,...

Zookeeper使用详解之常见操作篇(zookeeper ui)

一、Zookeeper的数据结构对于ZooKeeper而言,其存储结构类似于文件系统,也是一个树形目录服务,并通过Key-Value键值对的形式进行数据存储。其中,Key由斜线间隔的路径元素构成。对...

zk源码—4.会话的实现原理一(会话层的基本功能是什么)

大纲1.创建会话...

Zookeeper 可观测性最佳实践(zookeeper能够确保)

Zookeeper介绍ZooKeeper是一个开源的分布式协调服务,用于管理和协调分布式系统中的节点。它提供了一种高效、可靠的方式来解决分布式系统中的常见问题,如数据同步、配置管理、命名服务和集群...

服务器密码错误被锁定怎么解决(服务器密码错几次锁)

#服务器密码错误被锁定解决方案当服务器因多次密码错误导致账户被锁定时,可以按照以下步骤进行排查和解决:##一、确认锁定状态###1.检查账户锁定状态(Linux)```bash#查看账户锁定...

zk基础—4.zk实现分布式功能(分布式zk的使用)

大纲1.zk实现数据发布订阅...

《死神魂魄觉醒》卡死问题终极解决方案:从原理到实战的深度解析

在《死神魂魄觉醒》的斩魄刀交锋中,游戏卡死犹如突现的虚圈屏障,阻断玩家与尸魂界的连接。本文将从技术架构、解决方案、预防策略三个维度,深度剖析卡死问题的成因与应对之策,助力玩家突破次元壁障,畅享灵魂共鸣...

取消回复欢迎 发表评论: