异步 HTTP 请求

fetch 是一个用于进行异步 HTTP 请求的 JavaScript API。

fetch 基本用法

// 使用 fetch 进行 GET 请求
fetch('https://api.example.com/data').then(response => {// 检查响应是否成功if (!response.ok) {throw new Error('Network response was not ok');}// 解析响应数据为 JSONreturn response.json();}).then(data => {// 处理 JSON 数据console.log(data);}).catch(error => {// 处理错误console.error('There has been a problem with your fetch operation:', error);});

发送 POST 请求

// 使用 fetch 进行 POST 请求
fetch('https://api.example.com/data', {method: 'POST', // 指定请求方法为 POSTheaders: {'Content-Type': 'application/json' // 设置请求头},body: JSON.stringify({key1: 'value1',key2: 'value2'}) // 将数据转换为 JSON 字符串
}).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 has been a problem with your fetch operation:', error);});

处理不同的响应格式

fetch('https://api.example.com/data').then(response => {// 处理文本响应return response.text();}).then(text => {console.log(text);});fetch('https://api.example.com/image').then(response => {// 处理 Blob 响应return response.blob();}).then(blob => {const img = document.createElement('img');img.src = URL.createObjectURL(blob);document.body.appendChild(img);});

使用 Async/Await

async function fetchData() {try {const response = await fetch('https://api.example.com/data');if (!response.ok) {throw new Error('Network response was not ok');}const data = await response.json();console.log(data);} catch (error) {console.error('There has been a problem with your fetch operation:', error);}
}fetchData();

错误处理

处理错误时,fetch 只会在网络故障或请求被阻止的情况下拒绝 Promise。对于 HTTP 错误状态码(如 404 或 500),需要手动检查响应的 ok 属性:

fetch('https://api.example.com/data').then(response => {if (!response.ok) {throw new Error('HTTP error! status: ' + response.status);}return response.json();}).then(data => {console.log(data);}).catch(error => {console.error('There has been a problem with your fetch operation:', error);});

fetch 并行的异步请求

// 定义要获取的 URL 列表
const urls = ['https://api.example.com/data1','https://api.example.com/data2','https://api.example.com/data3'
];// 使用 fetch 并行请求所有 URL
Promise.all(urls.map(url => fetch(url))).then(responses => {// 检查所有响应是否都成功responses.forEach(response => {if (!response.ok) {throw new Error(`Network response was not ok for ${response.url}`);}});// 将所有响应解析为 JSONreturn Promise.all(responses.map(response => response.json()));}).then(dataArray => {// 处理所有解析后的数据console.log(dataArray);}).catch(error => {// 处理任何请求中的错误console.error('There has been a problem with your fetch operation:', error);});

 Async/Await 进行并行请求

async function fetchDataInParallel(urls) {try {// 并行请求所有 URLconst responses = await Promise.all(urls.map(url => fetch(url)));// 检查所有响应是否都成功responses.forEach(response => {if (!response.ok) {throw new Error(`Network response was not ok for ${response.url}`);}});// 将所有响应解析为 JSONconst dataArray = await Promise.all(responses.map(response => response.json()));// 处理所有解析后的数据console.log(dataArray);} catch (error) {// 处理任何请求中的错误console.error('There has been a problem with your fetch operation:', error);}
}// 定义要获取的 URL 列表
const urls = ['https://api.example.com/data1','https://api.example.com/data2','https://api.example.com/data3'
];// 调用 fetchDataInParallel 函数
fetchDataInParallel(urls);

更多内容

使用 Fetch - Web API | MDN

https://www.ruanyifeng.com/blog/2020/12/fetch-tutorial.html

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

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

相关文章

服务器超融合是什么意思?

你有没有听说过超融合架构?为什么最近这么多企业开始关注它?超融合架构正逐渐成为一种热门的解决方案。它不仅改变了传统IT基础设施的构建方式,还为企业提供了更高效、更灵活的资源管理。 超融合(Hyper-Converged Infrastructure…

一探究竟:如何高效提取ULL中的当前参数,实现性能与精度的完美平衡

一探究竟:如何高效提取ULL中的当前参数,实现性能与精度的完美平衡 你是否在开发过程中,遇到过那些复杂的、动态变化的URL?每次需要从中提取参数时,你的代码是不是开始变得杂乱无章,难以维护?特…

Vue.js组件开发-如何处理跨域请求

在Vue.js组件开发中,处理跨域请求(CORS,即跨来源资源共享)通常不是直接在Vue组件中解决的,而是需要后端服务器进行相应的配置,以允许来自不同源的请求。不过,前端开发者也需要了解一些基本的COR…

前端:前端开发任务分解 / 开发清单

一、背景 前端开发过程中,好多任务同时开发,或者一个大的任务分解为若干个子任务进行开发,分解出去的很多内容容易记不清楚 / 不易过程管理,所以记录表格如下,方便开发同事,也辅助掌握整体开发情况。 二、…

unity学习17:unity里的旋转学习,欧拉角,四元数等

目录 1 三维空间里的旋转与欧拉角,四元数 1.1 欧拉角比较符合直观 1.2 四元数 1.3 下面是欧拉角和四元数的一些参考文章 2 关于旋转的这些知识点 2.1 使用euler欧拉角旋转 2.2 使用quaternion四元数,w,x,y,z 2.3 使用quaternion四元数,类 Vector3.zero 这种…

Three.js计算机与反射艺术相结合

反射-CSDN直播反射映象https://live.csdn.net/v/460090 一.CSS部分 body {margin: 0;padding: 0;height: 100vh;overflow: hidden;display: flex;align-items: center;justify-content: center;background: black; }二.JS部分 //wccchallenge - reflection //reflection for…

PDF文件提取开源工具调研总结

概述 PDF是一种日常工作中广泛使用的跨平台文档格式,常常包含丰富的内容:包括文本、图表、表格、公式、图像。在现代信息处理工作流中发挥了重要的作用,尤其是RAG项目中,通过将非结构化数据转化为结构化和可访问的信息&#xff0…

从AI生成内容到虚拟现实:娱乐体验的新边界

引言 在快速发展的科技时代,娱乐行业正经历一场前所未有的变革。传统的娱乐方式正与先进技术融合,创造出全新的沉浸式体验。从AI生成的个性化内容,到虚拟现实带来的身临其境的互动场景,科技不仅改变了我们消费娱乐的方式&#xf…

pthread_create函数

函数原型 pthread_create 是 POSIX 线程&#xff08;pthread&#xff09;库中的一个函数&#xff0c;用于在程序中创建一个新线程。 #include <pthread.h>int pthread_create(pthread_t *thread, const pthread_attr_t *attr,void *(*start_routine) (void *), void *a…

《offer 来了:Java 面试核心知识点精讲 -- 原理篇》

在 Java 面试的战场上&#xff0c;只知皮毛可不行&#xff0c;面试官们越来越看重对原理的理解。今天就给大家分享一本能让你在面试中脱颖而出的 “武林秘籍”——《offer 来了&#xff1a;Java 面试核心知识点精讲 -- 原理篇》。 本书详细介绍了Java架构师在BAT和移动互联网公…

家政服务小程序,打造智慧家政新体验

春节即将来临&#xff0c;家政市场呈现出了火热的场景&#xff0c;大众对家政服务的需求持续增加。 近年来&#xff0c;家政市场开始倾向数字化、智能化&#xff0c;借助科学技术打造家政数字化平台&#xff0c;让大众在手机上就可以预约家政服务&#xff0c;减少传统家政市场…

vim练级攻略(精简版)

vim推荐配置: curl -sLf https://gitee.com/HGtz2222/VimForCpp/raw/master/install.sh -o ./install.sh && bash ./install.sh 0. 规定 Ctrl-λ 等价于 <C-λ> :command 等价于 :command <回车> n 等价于 数字 blank字符 等价于 空格&#xff0c;tab&am…

doris: Flink导入数据

使用 Flink Doris Connector 可以实时的将 Flink 产生的数据&#xff08;如&#xff1a;Flink 读取 Kafka&#xff0c;MySQL 中的数据&#xff09;导入到 Doris 中。 使用限制​ 需要依赖用户部署的 Flink 集群。 使用 Flink 导入数据​ 使用 Flink 导入数据&#xff0c;详…

Java-数据结构-二叉树习题(1)

对于二叉树的学习&#xff0c;主要的还是得多多练习~毕竟二叉树属于新的知识&#xff0c;并且也并不是线性结构&#xff0c;再加上经常使用递归的方法解决二叉树的问题&#xff0c;所以代码的具体流程还是无法看到的&#xff0c;只能通过画图想象&#xff0c;所以还是必须多加练…

PCL K4PCS算法实现点云粗配准【2025最新版】

目录 一、算法原理1、算法概述2、算法流程3、参考文献二、 代码实现1、原始版本2、2024新版三、 结果展示本文由CSDN点云侠原创,原文链接,首发于:2020年4月27日。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的抄袭狗。 博客长期更新,本文最近一次更新时间为…

09-1_信号量的理论讲解

09-1_信号量的理论讲解 信号量是操作系统中的一种同步和互斥机制&#xff0c;它通过一个计数值来表示资源的数量。通过这种方式&#xff0c;信号量可以有效地协调不同任务之间的资源使用。今天我们将深入学习信号量的基本概念、分类以及如何使用它们。 1. 信号量的基本概念 …

基于SSM汽车美容管家【提供源码+答辩PPT+文档+项目部署】(高质量源码,可定制,提供文档,免费部署到本地)

作者简介&#xff1a;✌CSDN新星计划导师、Java领域优质创作者、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java技术领域和学生毕业项目实战,高校老师/讲师/同行前辈交流。✌ 主要内容&#xff1a;&#x1f31f;Java项目、Python项目、前端项目、PHP、ASP.NET、人工智能…

Android 调用系统服务接口获取屏幕投影(需要android.uid.system)

媒体投影 借助 Android 5&#xff08;API 级别 21&#xff09;中引入的 android.media.projection API&#xff0c;您可以将设备屏幕中的内容截取为可播放、录制或投屏到其他设备&#xff08;如电视&#xff09;的媒体流。 Android 14&#xff08;API 级别 34&#xff09;引入…

SpringBoot源码解析(七):应用上下文结构体系

SpringBoot源码系列文章 SpringBoot源码解析(一)&#xff1a;SpringApplication构造方法 SpringBoot源码解析(二)&#xff1a;引导上下文DefaultBootstrapContext SpringBoot源码解析(三)&#xff1a;启动开始阶段 SpringBoot源码解析(四)&#xff1a;解析应用参数args Sp…

LVGL的优化

1&#xff0c;启动独立送显示线程&#xff1b; 2&#xff0c;添加主线程和display线程同步操作。 LVGL diplay单buffer&#xff1a; ----------- flush_cb()在GUI主线程渲染完成一帧后调用&#xff0c;输入变更区域&#xff0c;和变更帧数据指针: 1&#xff0c; 发送帧更新…