QQ登录

只需要一步,快速开始

APP扫码登录

只需要一步,快速开始

手机号码,快捷登录

泡泡马甲APP 更多内容请下载泡泡马甲手机客户端APP 立即下载 ×
查看: 203|回复: 0

[HTML/CSS/JS] fetch的使用

[复制链接]

等级头衔

积分成就    金币 : 2804
   泡泡 : 1516
   精华 : 6
   在线时间 : 1243 小时
   最后登录 : 2024-5-2

丰功伟绩

优秀达人突出贡献荣誉管理论坛元老

联系方式
发表于 2023-7-23 07:09:33 | 显示全部楼层 |阅读模式
在Web开发中,获取数据是常见的任务之一。fetch是一种在JavaScript中发送HTTP请求和获取响应的方法。fetch使用Promise对响应进行封装,比传统的XHR请求更容易使用。本文将介绍如何在JavaScript中使用Fetch,并提供一个实际的示例。$ ]) Q' ~/ h1 }& F6 ~0 T
发送请求1 \" E2 Q+ x- T0 j- m
使用fetch发送请求很简单,只需要提供请求URL和可选参数即可。
3 J9 N! d* X% F% y1 Q* j: h
  1. fetch('https://www.XXX.com/todos/1')
  2.   .then(response => response.json())
  3.   .then(data => console.log(data));
在上面的示例中,我们向一个API发送了一个请求,并用.then()方法链式地调用了两个回调函数。' \0 }0 G2 }% l  V5 g
第一个.then()方法的参数是响应对象response。它提供了很多有用的方法,例如.json(),它将响应转换为JSON格式。# X5 f9 b! S0 t9 n7 |. z: |% ~& r
第二个.then()方法的参数是由.json()解析出的数据对象data。在这个示例中,我们只是将数据输出到控制台上。
* m* U$ u- q9 D6 e在这里需要注意的是,fetch随着Promise的链式调用而进入回调函数,如果遇到了错误,它会返回rejected状态的Promise对象。因此,在终止回调链之前应始终使用.catch()处理错误。
, ?# ?8 j+ p' V) w
  1. fetch('https://www.XXX.com/todos/0')
  2.   .then(response => {
  3.     if (!response.ok) {
  4.       throw new Error('网络错误');
  5.     }
  6.     return response.json();
  7.   })
  8.   .then(data => console.log(data))
  9.   .catch(error => console.log(error));
在上面的示例中,我们向一个不存在的API发送了一个请求,因此响应对象的.ok属性为false。在.then()方法中,我们使用throw语句来抛出一个错误。在.catch()方法中,我们捕获了这个错误并输出它的信息。( ]  p7 T9 ]( Z' o8 ~: z
发送POST请求
0 m# k- g' C  l' Xfetch也可以用来发送POST请求。要发送POST请求,需要使用Request对象传递请求方法和请求头。要注意的是,fetch默认使用GET请求。
9 Z- _" I' c/ t% R9 S
  1. fetch('https://www.XXX.com/api', {
  2.   method: 'POST',
  3.   headers: {
  4.     'Content-Type': 'application/json'
  5.   },
  6.   body: JSON.stringify({
  7.     username: 'user',
  8.     password: 'pass'
  9.   })
  10. }).then(response => response.json())
  11.   .then(data => console.log(data));
在上面的示例中,我们向一个API发送了一个POST请求。我们使用JSON.stringify()将待发送的数据对象转换为JSON格式,并在请求头中设置Content-Type。- y' U" n+ [1 |, k
处理二进制数据
9 V3 A% E* h' K: ufetch也可以处理二进制数据,如Blob、File和FormData等。以下是一个示例代码,演示如何下载二进制文件:8 @. g0 E& X: A7 U3 \' ]
  1. fetch('https://www.XXX.com/img.png')
  2.   .then(response => response.blob())
  3.   .then(blob => {
  4.     const url = URL.createObjectURL(blob);
  5.     const img = document.createElement('img');
  6.     img.src = url;
  7.     document.body.appendChild(img);
  8.   });
在上面的示例中,我们向一个URL发送了一个请求,并使用blob()方法将响应转换为Blob对象。我们使用URL.createObjectURL()方法将Blob对象转换为可用于显示图像的URL。最后,我们将图像的URL添加到文档中。7 L0 G/ I3 l  E, X) f! D
总结
0 _% S' y2 o2 g8 r" R3 ffetch是一种用于在JavaScript中发送HTTP请求和获取响应的方法。它使用Promise封装响应,比传统的XHR请求更容易使用。在本文中,我们介绍了如何使用fetch发送请求、如何发送POST请求、如何处理二进制数据。fetch简单易用,使用时需要注意的是,我们需要处理rejected状态的Promise对象,以及进行错误处理。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|手机版|小黑屋|paopaomj.COM ( 渝ICP备18007172号 )

GMT+8, 2024-5-4 01:22

Powered by paopaomj X3.4 © 2016-2024 sitemap

快速回复 返回顶部 返回列表