Chaper 09 深入理解Promise

news2025/1/14 1:14:51

文章目录

  • 前言
  • 一、异步编程
  • 二、Promise


前言

在JavaScript中,异步编程是一个重要的概念。随着应用程序的复杂性增加,处理异步操作的方式也变得更加复杂。Promise是一种用于处理异步操作的对象,它提供了一种更清晰和更强大的方式来管理异步代码。本章详细讲解了Promise的基本用法以及链式调用。

一、异步编程

①定义
异步编程是一种编程范式,它允许程序在执行某些操作时不阻塞主线程,从而提高应用程序的效率和响应性。在异步编程中,程序可以在等待某些操作(如网络请求、文件读取或数据库查询)完成的同时继续执行其他任务。

②关键概念

  • 非阻塞:在异步编程中,程序不会等待某个操作完成后再继续执行,而是可以同时处理多个操作。即使某个操作需要较长时间,程序仍然可以响应用户输入或执行其他任务。
  • 回调函数:传统的异步编程通常使用回调函数来处理异步操作的结果。当异步操作完成时,回调函数会被调用。这种方式可能导致“回调地狱”,使代码难以阅读和维护。
  • Promise:Promise是JavaScript中处理异步操作的一种方式。它表示一个可能在未来某个时间点完成的操作,并提供了thencatch方法来处理成功和失败的结果。
  • async/awaitasyncawait是ES2017引入的语法糖,使得异步代码看起来更像同步代码。使用async关键字定义一个异步函数,并在函数内部使用await来等待Promise的结果。

【示例】
以下是一个简单的异步编程示例,使用setTimeout模拟异步操作:

console.log("开始");

setTimeout(() => {
    console.log("异步操作完成");
}, 2000);

console.log("结束");

运行结果:
开始
结束
异步操作完成

【分析】
setTimeout 函数设置了一个异步操作,该操作会在2秒后执行,输出“异步操作完成”。

二、Promise

①基本概念
Promise是一个表示异步操作最终完成(或失败)及其结果值的对象。Promise有以下三种状态:

  • Pending(待定): 初始状态,既不是成功,也不是失败。
  • Fulfilled(已兑现): 操作成功完成。
  • Rejected(已拒绝): 操作失败。

一旦Promise的状态从Pending变为Fulfilled或Rejected,就不能再改变。

②基本用法

const myPromise = new Promise((resolve, reject) => {  
    const success = true; // 模拟成功或失败  

    if (success) {  
        resolve("操作成功!");  
    } else {  
        reject("操作失败!");  
    }  
});  

myPromise  
    .then(result => {  
        console.log(result); // 输出: 操作成功!  
    })  
    .catch(error => {  
        console.error(error); // 输出: 操作失败!  
    });  
  • new Promise(...):Promise构造函数,用于创建一个新的Promise对象。该构造函数接受一个执行器函数作为参数。
  • (resolve, reject) => { ... }:执行器函数,是一个回调函数,在Promise创建时立即执行,它包含了异步操作的逻辑。
    • 参数resolve: 一个函数,用于将Promise的状态从“待定”(Pending)变为“已兑现”(Fulfilled)。当异步操作成功完成时调用它,并传递结果值。
    • 参数reject: 一个函数,用于将Promise的状态从“待定”(Pending)变为“已拒绝”(Rejected)。当异步操作失败时调用它,并传递错误信息。
  • const success = true;:定义了一个变量success,用于模拟异步操作的结果。
  • resolve("操作成功!");:成功回调。当successtrue时,调用resolve函数并传递字符串“操作成功!”作为结果。此时,Promise的状态变为“已兑现”,并将结果传递给后续的then方法进行处理。
  • reject("操作失败!");:失败回调。当successfalse时,调用reject函数并传递字符串“操作失败!”作为错误信息。此时,Promise的状态变为“已拒绝”,并将错误信息传递给后续的catch方法进行处理。
  • myPromise.then(...):处理成功结果。 then方法用于处理Promise成功兑现后的结果。它接受一个回调函数作为参数,该函数将在Promise成功时被调用,并接收resolve传递的结果。
  • .catch(...):处理失败结果。catch方法用于处理Promise被拒绝后的错误。它接受一个回调函数作为参数,该函数将在Promise失败时被调用,并接收reject传递的错误信息。

【示例】

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        /* 使用Promise管理异步任务 */
        // 1.创建Promise对象
        const myPromise=new Promise((resolve,reject)=>{
            // 2.执行异步代码
            setTimeout(()=>{
                resolve('模拟AJAX请求——成功结果')
            },2000)
        })
        // 3.获取结果
        myPromise.then(result=>{
            console.log(result)
        }).catch(err=>{
            console.log(error)
        })
    </script>
</body>
</html>

运行结果:
在这里插入图片描述
异步代码修改为如下:

setTimeout(()=>{
                reject(new Error('模拟AJAX请求——失败结果'))
            },2000)

运行结果:
在这里插入图片描述

③链式调用
定义:
Promise允许开发者处理异步操作,并通过then()方法返回一个新的Promise,从而实现链式调用。每个then()方法可以接收前一个Promise的结果,并返回一个新的Promise,继续进行后续的操作。

优点:

  • 清晰性:代码没有深层嵌套而是通过链式调用串联在一起,避免了深层嵌套,代码逻辑更清晰。
  • 异步处理:通过链式调用,Promise的每一部分都是独立的,可以轻松处理多个异步操作。
  • 错误处理:如果在任意一个then中抛出错误,整个链的后续部分都可以通过catch()方法捕获和处理,避免了传统回调的错误传递问题。

【注意】
then()回调函数中的返回值,会影响新生成的Promise对象的最终状态和结果

【示例】

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        /* 
        目标:掌握Promise的链式调用
        需求:把省市的嵌套结构改成链式调用的学校结果
        */
        // 1.创建Promise对象——模拟请求省份名字
        const p=new Promise((resolve,reject)=>{
            // 2.执行异步代码
            setTimeout(()=>{
                resolve('北京市')
            },2000)
        })
        // 3.获取省份名字
        const p2=p.then(result=>{
            console.log(result)
            // 4.创建Promise对象——模拟请求城市名字
            // return Promise对象最终状态和结果会影响新的Promise对象
            return new Promise((resolve,reject)=>{
                setTimeout(()=>{
                    resolve(result+'---北京')
                },2000)
            })
        })

        // 5.获取城市名字
        p2.then(result=>{
            console.log(result)
        })
    </script>
</body>
</html>

运行结果:
在这里插入图片描述
【分析】
这段代码通过链式调用的方式处理异步操作。首先,通过Promise获取省份,然后在获取成功后继续获取城市,保持代码结构清晰可读且不容易出现回调地狱的情况。在这里插入图片描述

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

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

相关文章

智能的JavaScript开发工具WebStorm v2024.2全新发布

WebStorm 是jetbrains公司旗下一款JavaScript 开发工具&#xff0c;被广大中国JS开发者誉为"Web前端开发神器""强大的HTML5编辑器""智能的JavaSscript IDE"等。与IntelliJ IDEA同源&#xff0c;继承了IntelliJ IDEA强大的JS部分的功能。 立即获…

学生防近视台灯什么品牌好?学生护眼台灯怎么选?收下这份攻略

根据中国报告大厅的数据&#xff0c;近年来&#xff0c;随着科技的不断进步&#xff0c;台灯行业亦得到了快速发展。早期的台灯主要采用白炽灯作为光源&#xff0c;但随着LED技术的日益成熟&#xff0c;LED台灯已成为市场主流。目前&#xff0c;台灯行业正处于高速发展阶段&…

【吊打面试官系列-Redis面试题】Redis 过期键的删除策略?

大家好&#xff0c;我是锋哥。今天分享关于 【Redis 过期键的删除策略】面试题&#xff0c;希望对大家有帮助&#xff1b; Redis 过期键的删除策略&#xff1f; 1000道 互联网大厂Java工程师 精选面试题-Java资源分享网 1、定时删除:在设置键的过期时间的同时&#xff0c;创建…

19 - 路径搜索的综合

---- 整理自狄泰软件唐佐林老师课程 文章目录 1. 需求2. 一些工具3. 编译规则的依赖4. 实验 1. 需求 工程项目中不希望源码文件夹在编译时被改动&#xff08;只读文件夹&#xff09;在编译时自动创建文件夹&#xff08;build&#xff09;用于存放编译结果编译过程中能够自动搜…

java基本程序设计结构与数据类型

1.一个简单程序的编写、编译与运行 编写如下的Main.java public class Main{public static void main(String[] args){System.out.println("Hello World");} }上面的程序有几个要注意的点&#xff1a; ①public 是访问修饰符&#xff0c;用来表示其他程序对Main类的…

【C++】vector(下)--下篇

个人主页~ vector&#xff08;上&#xff09;~ vector&#xff08;下&#xff09;–上篇~ vector 二、模拟实现3、test.cpptest1test2test3test4test5test6 三、一个难题 二、模拟实现 3、test.cpp test1 这个没啥好说的&#xff0c;就是尾插和迭代器都能正常使用 //测尾…

中国各、省、市、县、乡镇基尼系数数据(2000-2023年)

基尼系数是一个国际上广泛用来综合考察居民内部收入分配差异状况的重要指标。它表示在全部居民收入中&#xff0c;用于进行不平均分配的那部分收入占总收入的百分比。基尼系数的值介于0和1之间&#xff0c;其中0代表收入分配绝对平均&#xff0c;即每个人的收入都相等&#xff…

Qt21基础图形的绘制

基础图形的绘制 paintareapaintarea.hpaintarea.cpp paintexpaintex.hpaintex.cpp main.cpp运行图 paintarea paintarea.h #ifndef PAINTAREA_H #define PAINTAREA_H#include <QWidget> #include <QBrush> #include <QPen> #include <QPainter> #inc…

DZ主题模板 Discuz迪恩淘宝客购物风格商业版模板

Discuz淘宝客网站模板&#xff0c;迪恩淘宝客购物风格商业版模板。 版本支持&#xff1a;discuzx3.0版本,discuzx3.1版本,discuzx3.2版本。 包括网站首页&#xff0c;论坛首页&#xff0c;论坛列表页&#xff0c;论坛内容页&#xff0c;论坛瀑布流,频道列表页&#xff0c;频道…

开学季好物合集有哪些?全方位必备好物推荐

随着秋风轻拂&#xff0c;书页翻新的声音在耳边悄然响起&#xff0c;我们迎来了又一个开学季。在这个特别的时刻&#xff0c;每位学子都怀揣着对未来的无限憧憬&#xff0c;踏入了校园的大门。为了帮助大家更好地适应新学期的学习节奏&#xff0c;享受更加充实而愉快的校园生活…

解决Linux安装epel源提示没有可用安装包

目录 前言 常规方法总结 1、命令直接安装 2、通过网址下载安装 手动安装 1、EPEL的资源地址 2、选择版本 3、找到rpm文件存放位置 4、下载并移动至虚拟机中 5、安装 6、成功后会生成相应的repo文件 7、更新源 前言 EPEL&#xff0c; 即Extra Packages for Enterpri…

STM32开发资料

文章目录 前言一、正点原子&#xff1f;1. 资料链接2.论坛3.参考资料盘 二、野火1. 论坛2. 资料链接 总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 学习需要&#xff1a;找一个开发板的资料作为基础 提示&#xff1a;以下是本篇文章正文内容&…

Redis 键值对操作全攻略

文章目录 一 . get 和 set二 . keys *三 . exists四 . del五 . expire六 . ttl七 . Redis 的 key 的过期策略八 . 定时器的实现8.1 基于优先级队列8.2 基于时间轮实现的定时器 九 . type十 . 数据库管理相关命令 Hello , 大家好 , 这个专栏给大家带来的是 Redis 系列 ! 本篇文章…

聊聊客户端/服务器与订阅/发布两大模型

正文 大家好&#xff0c;我是bug菌&#xff5e; 在项目开发中根据不同的应用场景通常会去尝试各种各样的通信方式&#xff0c;可能试来试去可能又回到了原地&#xff0c;而对于一个相对比较大的网络系统&#xff0c;不同的场景得考量不同的通信架构模型&#xff0c;那么今天就跟…

面向对象23种设计模式通俗理解

终点即是起点,自强不息! 设计模式的理解 设计模式是为了可重用代码、让代码更容易被他人理解、保证代码可靠性。 模式&#xff1a;在某些场景下&#xff0c;针对某类问题的某种通用的解决方案。 场景&#xff1a;项目所在的环境 问题&#xff1a;约束条件&#xff0c;项目目标…

慷智serdes调试记录(AIM951-958)

项目使用的是AIM951~958 951和958测试图谱输出 下面是两种1920*1080不同屏幕timing的951图谱输出&#xff08;一般我们提供屏幕timing&#xff0c;然后找慷智FAE要下寄存器配置&#xff0c;他有一个xcel文档&#xff0c;可以自己设置屏幕timing然后得到寄存器设置值&#xff…

Vue 3 Composition API 中如何正确添加表单项副本到数组

在 Vue 3 中&#xff0c;使用 Composition API 时&#xff0c;如果你尝试直接通过引用&#xff08;如 formState&#xff09;来填充 formList 数组&#xff0c;你会遇到一个问题&#xff1a;所有通过 addForm 方法添加的表单项实际上都是对 formState 的同一个引用。这意呀着&a…

K3 给K+增加日志(获取机器名和IP地址)

K3有个外挂系统是K&#xff0c;可以对数据进行修改&#xff0c;但是没有日志功能&#xff0c;谁修改了什么、什么时候修改的不知道&#xff0c;借鉴t_log做一个日志 1、先建一个日志表 CREATE TABLE [dbo].[kplus_log]([FlogID] [int] IDENTITY(1,1) NOT NULL,[FDate] [datet…

CST软件如何计算天线fidelity保真度?达索代理思茂信息

天线保真度&#xff08;fidelity&#xff09;是指辐射信号和输入信号的相似程度&#xff0c;用最大归一化值表示[-1&#xff0c;1]。单独天线的保真度用端口激励信号和空间探针接收信号计算&#xff1b;双天线的保真度可用接收天线端口信号和发射天线的激励信号计算。所以在一定…

基于深度学习的谣言监测系统-毕业设计

介绍 本项目是一款基于深度学习的谣言监测系统&#xff0c;利用 LSTM 模型实现对网络谣言的自动识别和监测。在互联网和社交媒体高速发展的背景下&#xff0c;本项目的推出具有重要意义&#xff0c;旨在提高谣言识别的准确性和效率&#xff0c;帮助公众快速辨别真伪信息&#…