JavaScript学习 -- fetch的使用

简介: JavaScript学习 -- fetch的使用

在Web开发中,获取数据是常见的任务之一。fetch是一种在JavaScript中发送HTTP请求和获取响应的方法。fetch使用Promise对响应进行封装,比传统的XHR请求更容易使用。本文将介绍如何在JavaScript中使用Fetch,并提供一个实际的示例。

发送请求

使用fetch发送请求很简单,只需要提供请求URL和可选参数即可。

fetch('https://jsonplaceholder.typicode.com/todos/1')
  .then(response => response.json())
  .then(data => console.log(data));

在上面的示例中,我们向一个API发送了一个请求,并用.then()方法链式地调用了两个回调函数。

第一个.then()方法的参数是响应对象response。它提供了很多有用的方法,例如.json(),它将响应转换为JSON格式。

第二个.then()方法的参数是由.json()解析出的数据对象data。在这个示例中,我们只是将数据输出到控制台上。

在这里需要注意的是,fetch随着Promise的链式调用而进入回调函数,如果遇到了错误,它会返回rejected状态的Promise对象。因此,在终止回调链之前应始终使用.catch()处理错误。

fetch('https://jsonplaceholder.typicode.com/todos/0')
  .then(response => {
    if (!response.ok) {
      throw new Error('网络错误');
    }
    return response.json();
  })
  .then(data => console.log(data))
  .catch(error => console.log(error));

在上面的示例中,我们向一个不存在的API发送了一个请求,因此响应对象的.ok属性为false。在.then()方法中,我们使用throw语句来抛出一个错误。在.catch()方法中,我们捕获了这个错误并输出它的信息。

发送POST请求

fetch也可以用来发送POST请求。要发送POST请求,需要使用Request对象传递请求方法和请求头。要注意的是,fetch默认使用GET请求。

fetch('https://example.com/api', {
  method: 'POST',
  headers: {
    'Content-Type': 'application/json'
  },
  body: JSON.stringify({
    username: 'user',
    password: 'pass'
  })
}).then(response => response.json())
  .then(data => console.log(data));

在上面的示例中,我们向一个API发送了一个POST请求。我们使用JSON.stringify()将待发送的数据对象转换为JSON格式,并在请求头中设置Content-Type。

处理二进制数据

fetch也可以处理二进制数据,如Blob、File和FormData等。以下是一个示例代码,演示如何下载二进制文件:

fetch('https://example.com/img.png')
  .then(response => response.blob())
  .then(blob => {
    const url = URL.createObjectURL(blob);
    const img = document.createElement('img');
    img.src = url;
    document.body.appendChild(img);
  });

在上面的示例中,我们向一个URL发送了一个请求,并使用blob()方法将响应转换为Blob对象。我们使用URL.createObjectURL()方法将Blob对象转换为可用于显示图像的URL。最后,我们将图像的URL添加到文档中。

总结

fetch是一种用于在JavaScript中发送HTTP请求和获取响应的方法。它使用Promise封装响应,比传统的XHR请求更容易使用。在本文中,我们介绍了如何使用fetch发送请求、如何发送POST请求、如何处理二进制数据。fetch简单易用,使用时需要注意的是,我们需要处理rejected状态的Promise对象,以及进行错误处理。

目录
相关文章
|
2月前
|
Web App开发 JavaScript 前端开发
如何学习JavaScript?
如何学习JavaScript?
52 5
|
2月前
|
JavaScript 前端开发 索引
JavaScript学习第二章--字符串
本文介绍了JavaScript中的字符串处理,包括普通字符串和模板字符串的使用方法及常见字符串操作方法如`charAt`、`concat`、`endsWith`等,适合前端学习者参考。作者是一位热爱前端技术的大一学生,专注于分享实用的编程技巧。
34 2
|
2月前
|
存储 JavaScript 前端开发
JavaScript学习第一章
本文档介绍了JavaScript的基础知识,包括其在网页中的作用、如何通过JavaScript动态设置HTML元素的CSS属性,以及JavaScript中的变量类型(`var`、`let`、`const`)和数据类型(基本数据类型与引用数据类型)。通过实例代码详细解释了JavaScript的核心概念,适合初学者入门学习。
56 1
|
3月前
|
JavaScript
webpack学习五:webpack的配置文件webpack.config.js分离,分离成开发环境配置文件和生产环境配置文件
这篇文章介绍了如何将webpack的配置文件分离成开发环境和生产环境的配置文件,以提高打包效率。
58 1
webpack学习五:webpack的配置文件webpack.config.js分离,分离成开发环境配置文件和生产环境配置文件
|
3月前
|
JavaScript
js学习--商品列表商品详情
js学习--商品列表商品详情
32 2
|
3月前
|
JavaScript
js学习--九宫格抽奖
js学习--九宫格抽奖
24 2
|
3月前
|
JavaScript
js学习--开屏弹窗
js学习--开屏弹窗
49 1
|
3月前
|
JavaScript
js学习--抽奖
js学习--抽奖
25 1
|
3月前
|
JavaScript
js学习--隔行换色
js学习--隔行换色
33 1
|
3月前
|
JavaScript 前端开发 容器
js之dom学习
js之dom学习
53 0