【ES6】fetch函数和Promise

fetch函数是现代JavaScript中用于发起HTTP请求的一个非常强大的工具。它返回一个Promise,这个Promise在请求成功时解析为Response对象,或者在请求失败时拒绝。

以下是一个基本的fetch使用示例:

javascript 复制代码
fetch('https://api.example.com/data')
  .then(response => {
    // HTTP状态码为200表示请求成功
    if (response.status === 200) {
      return response.json();
    } else {
      throw new Error('网络请求失败');
    }
  })
  .then(data => console.log(data))
  .catch(error => console.error(error));

在这个例子中,我们首先向https://api.example.com/data发起一个GET请求。然后,我们检查响应的状态码。如果状态码是200,我们尝试将响应的内容解析为JSON。如果解析成功,我们将数据打印到控制台。如果解析失败,或者在任何其他步骤中发生错误,我们捕获这个错误并打印错误信息。

注意,fetch并不直接返回请求的结果,而是返回一个Promise。这是因为网络请求可能会异步完成,所以你不能直接从fetch调用中获取结果。相反,你需要使用then方法或者async/await语法来等待Promise解析。

下面是一个使用async/await语法的相同示例:

javascript 复制代码
async function fetchData() {
  try {
    let response = await fetch('https://api.example.com/data');
    if (response.status === 200) {
      let data = await response.json();
      console.log(data);
    } else {
      throw new Error('网络请求失败');
    }
  } catch (error) {
    console.error(error);
  }
}

fetchData();

在这个例子中,我们使用async/await语法来等待Promise解析。这使得我们的代码看起来更像是同步的代码,但是实际上它仍然是异步的。

相关推荐
superman超哥17 小时前
Rust 发布 Crate 到 Crates.io:从本地到生态的完整旅程
开发语言·后端·rust·crate·crates.io
浪客川17 小时前
【百例RUST - 002】流程控制 基础语法练习题
开发语言·rust
一路往蓝-Anbo17 小时前
C语言从句柄到对象 (二) —— 极致的封装:不透明指针与 SDK 级设计
c语言·开发语言·数据结构·stm32·单片机·嵌入式硬件
上天_去_做颗惺星 EVE_BLUE17 小时前
C++学习:学生成绩管理系统
c语言·开发语言·数据结构·c++·学习
雪域迷影17 小时前
使用Python库获取网页时报HTTP 403错误(禁止访问)的解决办法
开发语言·python·http·beautifulsoup·urllib
chao18984417 小时前
基于Qt的SSH/FTP远程文件管理与命令执行实现方案
开发语言·qt·ssh
凯子坚持 c17 小时前
Qt常用控件指南(1)
开发语言·数据库·qt
Flash.kkl17 小时前
Python基础语法
开发语言·python
十五年专注C++开发17 小时前
CMake进阶:find_package使用总结
开发语言·c++·cmake·跨平台编译
lxw184491251417 小时前
PHP凉了?岗位缩水50%+,开发者该何去何从?
开发语言·php