当前位置: 首页 > news >正文

Promise查漏及回调地狱结构优化

目录

  • 前言
  • 一、执行器函数的执行顺序
  • 二、如何在then()中抛出错误
  • 三、期约的"非重入"特性
  • 四、串行化期约
  • 五、应对回调地狱
  • 结语

前言

依据《JavaScript高级程序设计》对Promise期约相关进行查缺补漏.


一、执行器函数的执行顺序

执行器函数虽作为期约的参数, 却是期约的初始化程序在同步队列中执行, 即程序从上到下执行下来碰到期约, 会先在同步任务队列执行完执行器函数再进去期约.

ECMAScript暴露的异步结构中, 任何对象都有then方法, 而有实现了该方法的结构即被认为实现了thenable接口. Promise的原型上也实现了then()方法:

new Promise((resolve, reject) => {
...
}).then();

then()只接受函数类型参数且最多2个.


二、如何在then()中抛出错误

then(()=>{throw 'baz';
}); 	
then(()=>{Error('qux');
}) 

两种都正确,前者抛出报错;
后者返回一个包装于Promise对象中的错误对象可以反应调用栈情况, 以正常值输出.


三、期约的"非重入"特性

期约"落定"后, 处理程序(即then的参数函数onResolvedonRejected)仅会加入排期而非立即执行, 而排在处理程序后的同步语句会先执行, 此特性是由Javascript运行时保证的,即then内部语句的输出会晚于then外部更加靠后的语句的输出.
其原因为在一个落定期约上调用then虽会把then中的处理程序推进消息队列, 但在当前线程上的同步代码执行完成前处理程序依然不会被执行. 更符合常理一些的写法, 对一个已写入处理程序的期约落定后, 也会是这样的输出顺序.


四、串行化期约

期约连锁: then()内再构建期约, 串行化异步任务即:

new Promise((resolve, reject) => { console.log ('P1 executor'); setTimeout (resolve, 1000);
})
.then (() => { new Promise((resolve, reject) => { console.log('P2 executor'); setTimeout(resolve, 1000);
})
.then(() => {new Promise((resolve, reject) => { console.log('P3 executor'); setTimeout(resolve, 1000);
});

但书中似乎认为这种串行式结构并未解决回调地狱(未明确表明).


五、应对回调地狱

可见第四节这种串行结构有同质部分,如果将同质部分使用工厂函数调用生产,这种结构可以演化为:

function delayedResolve(str) {return new Promise((resolve, reject) => { console.log(str);setTimeout (resolve, 1000);});
}  //工厂函数delayResolve('P1 executor').then(() => { delayResolve('P2 executor');
})
.then(()=> {delayResolve('P3 executor')
})

每次调用"生产"返回一块期约对象同质部分,返回后相当于回到了期约串行结构:

new Promise().then(() => {delayResolve();
}).then()

上例期约体同质部分只分为一种,打比方如果上例有一段串行块的期约内还输出了1,这就是另一种同质部分,就要再单独为这段输出了1的期约构建工厂函数.

以上为基础,如果不使用期约,以回调函数形式唤起后续的异步操作就会是这样:

function delayedExecute(str, callback = null) { setTimeout(() => { callback && callback();}, 1000)
}delayedExecute('P1callback', () => {delayedExecute('P2callback', () => {delayedExecute('P3callback', () => { delayedExecute('P4callback');});});
});

《JavaScript高级程序设计》中称这样的一种结构, 破除了回调地狱.

那么这种结构到实战中,加上ajax请求就不能再每次传一个字面量,因为我们要模仿回调地狱里下个参数为上个结果的情况,就要把上次请求的结果传到下个回调函数内:

function delayedExecute(params, callback = null) { $.ajax({url: 'xx/xx',type:'post',data: { a: params.a, b: params.b },success (res) { callback && callback(res);}
})
}delayedExecute(data0, (res0) => {delayedExecute(res0, (res1) => {delayedExecute(res1, (res2) => { delayedExecute(res2);});});
});

结语

如有疏漏,请为我指正,谢谢.

相关文章:

Promise查漏及回调地狱结构优化

目录 前言一、执行器函数的执行顺序二、如何在then()中抛出错误三、期约的"非重入"特性四、串行化期约五、应对回调地狱结语 前言 依据《JavaScript高级程序设计》对Promise期约相关进行查缺补漏. 一、执行器函数的执行顺序 执行器函数虽作为期约的参数, 却是期约的…...

SpringCloud-05 Resilience4J 服务降级和熔断

服务雪崩:指在多个服务之间存在依赖关系时,当一个服务发生故障或不可用时,导致其他服务也无法正常工作的情况。这种现象通常是因为服务之间的依赖关系过于紧密,当一个服务发生故障时,其他服务无法正确处理该服务的请求…...

哈希表、算法

哈希表 hash: 在编程和数据结构中,"hash" 通常指的是哈希函数,它是一种算法,用于将数据(通常是字符 串)映射到一个固定大小的数字(哈希值)。哈希函数在哈希表中尤为重要…...

变更AWS EC2 实例配置或实例类型

在本文中,九河云将带您了解如何更改由 Amazon Elastic Block Store (EBS) 支持的 Amazon Elastic Compute Cloud (EC2) 实例的类型。更改实例类型可以优化成本和性能,使其更符合您的应用程序需求。 准备工作 在开始之前,请确保您已完成以下…...

【前端】ref引用的作用

首先&#xff0c;我们要明确一点&#xff0c;使用vue的好处是&#xff1a; 想要减少开发者直接操作dom元素。使用组件模版&#xff0c;实现代码的服用。 ref的属性的实现是为了取代原生js中使用id、class等标识来获取dom元素。 helloworld组件 <template><div clas…...

运用Java实现倒计时功能

这个功能其实是比较好实现的&#xff0c;一般来说java中实现倒计时有两种方法&#xff1a; 1、使用 scheduledexecutorservice创建一个可重复执行的任务&#xff0c;直到时间到&#xff1a; ScheduledExecutorService 是 Java 中一种用于安排延迟或定期任务的工具。我们可以使…...

Vue 第三方调用若依系统实现系统单点登录

应用场景 甲方现有平台系统拟集成我方新开发系统&#xff0c;实现单点登录功能&#xff0c;即用户登录主平台后&#xff0c;无需重复登录即可无缝访问新系统&#xff0c;提升用户体验与操作效率。 解决方案 实现代码 前端 Step:1 新建ssoLogin.vue页面 <template><d…...

IP纯净度对跨境电商有哪些影响

在全球化贸易的浪潮中&#xff0c;跨境电商凭借其打破地理界限的能力&#xff0c;成为推动国际贸易的重要力量。然而&#xff0c;跨境电商的运营并非没有挑战&#xff0c;其中IP纯净度是影响其成功的关键因素之一。本文将探讨IP纯净度对跨境电商运营的多方面影响&#xff0c;并…...

docker-01 创建一个自己的镜像并运行容器

docker-01 创建一个自己的镜像并运行容器 前言 我们都知道使用Docker的镜像可以快速创建和部署应用&#xff0c;大大的节约了部署的时间。并且Docker 的镜像提供了除内核外完整的运行时环境&#xff0c;确保代码的环境一致性&#xff0c;从而不会在出现这段代码在我机器上没问…...

国产视频转换HDMI1.4转单/双MIPI DSI/CSI LT6911C芯片方案,带音频输出,QFN64封装 Lontium

LT6911C:HDMI 1.4 TO MIPI DSI/CSI 芯片简介&#xff1a; LT6911C是一款高性能的HDMI1.4转换器MIPI DSI/CSI芯片用于VR/智能手机/显示应用。对于MIPI DSI/CSI输出&#xff0c;LT6911C功能可配置单端口或双端口MIPIDSI/CSI 1高速时钟通道和1~4个高速数据通道最大1.5Gb/s/lane&am…...

亚马逊、沃尔玛、敦煌网、Target塔吉特、Temu环境搭建测评技术!

海外跨境电商各大主要平台正不断力推半托管模式&#xff0c;不断对商家开出众多吸引和扶持政策。全托管是指电商平台全面负责店铺的运营&#xff0c;包括仓储、配送、售后等&#xff0c;而商家主要负责提供货品。半托管模式则基本由商家自主经营&#xff0c;平台只负责仓配物流…...

yjs05——matplotlib画其他图像

不管是折线图还是散点图&#xff0c;饼状图&#xff0c;柱状图等&#xff0c;其流程都是 1.创建幕布 ❤2.画图画坐标补充信息 3.保存图像 4.展示图像 不同就是在画图时候的代码不太相同 折线&#xff1a;plt.plot(x,y) 散点&#xff1a;plt.scatter() 柱状图&#xff1a;plt.hi…...

【C#】添加临时环境变量

在C#中&#xff0c;可以通过System.Environment类来添加临时环境变量。临时环境变量只在当前进程中有效&#xff0c;进程结束后变量即失效&#xff0c;不会写入系统的Path中。 using System;class Program {static void Main(){// 设置临时环境变量Environment.SetEnvironment…...

物联网之ESP32与微信小程序实现指示灯、转向灯

MENU ESP32微信小程序 ESP32 代码 #include <WiFi.h> #include <WebServer.h> #include <ArduinoJson.h>const char* ssid "jifu"; const char* pass "2022xinchan!#"; const int dateTime 500; const int ledPin4 4; const int le…...

ICPC网络赛 以及ACM训练总结

一、训练反思 关于我自己暑假期间训练的反思&#xff0c;我承认无论是因为什么原因&#xff0c;我自己浪费我整整一个暑假的时间&#xff0c;暑假期间正是我们集训的关键时期&#xff0c;这期间没有任何的事情来打扰我们学习&#xff0c;而我却熬夜&#xff0c;白天训练懈怠&a…...

优化深度学习模型训练过程:提升PASCAL VOC 2012数据集上Deeplabv3+模型训练效率的策略

创作不易&#xff0c;您的打赏、关注、点赞、收藏和转发是我坚持下去的动力&#xff01; 优化说明&#xff1a; 避免重复下载和解压数据集&#xff1a;将downloadTrue改为downloadFalse&#xff0c;防止每次运行代码都重新下载和解压数据集&#xff0c;从而节省时间。 使用pin…...

【乐吾乐大屏可视化组态编辑器】使用手册

1 总览 开始设计&#xff1a;大屏可视化设计器 - 乐吾乐Le5le 1.1 画布 画布即绘画区域&#xff0c;将图形拖拽到画布进行编辑&#xff0c;绘制大屏。 1.2 菜单栏 顶部菜单导航&#xff0c;一级菜单可设置Logo、公司名称、文件编辑、常用编辑、查看、帮助&#xff0c;设置大…...

uniapp+若依 开发租房小程序源码分享

1、使用Uniapp开发的前台&#xff0c;基于 Vue.js 开发所有前端应用的框架&#xff0c;开发者编写一套代码&#xff0c;可发布到iOS、Android、Web&#xff08;响应式&#xff09;、以及各种小程序 2、基于SpringBoot的权限管理系统&#xff0c;易读易懂、界面简洁美观。 核心…...

日系编曲:节奏吉他与主音吉他 吉他的节奏型 节奏吉他的编写思路 吉他的Riff

这篇文章介绍的是日系吉他编写中的多吉他编写思路&#xff01; 日系吉他构成特点 ​一般日系曲子构成有两把以上的吉他&#xff0c;根据需求来进行补充&#xff1a; 通常至少为一把主音一把节奏&#xff0c;一把左一把右&#xff0c;主音一般是电吉他&#xff0c;节奏可以是电…...

【网络安全的神秘世界】目录遍历漏洞

&#x1f31d;博客主页&#xff1a;泥菩萨 &#x1f496;专栏&#xff1a;Linux探索之旅 | 网络安全的神秘世界 | 专接本 | 每天学会一个渗透测试工具 先来了解两个概念&#xff1a; 身份认证&#xff1a;验证用户或者系统身份的过程&#xff0c;确保他们所声明的身份是真实的…...

PyTesseract实战:从参数调优到场景化OCR识别方案

1. PyTesseract入门&#xff1a;为什么参数调优如此重要&#xff1f; 第一次用PyTesseract做OCR识别时&#xff0c;我对着满屏乱码的输出结果差点崩溃——明明图片上的文字清晰可见&#xff0c;为什么识别结果却错得离谱&#xff1f;后来才发现&#xff0c;默认参数配置就像用菜…...

Windows远程桌面防爆破实战:用PowerShell自动封禁恶意IP(附完整脚本)

Windows远程桌面安全加固&#xff1a;基于PowerShell的智能IP封禁系统 远程桌面服务&#xff08;RDP&#xff09;作为企业IT基础设施的核心组件&#xff0c;其安全性直接关系到整个系统的稳定运行。根据2023年全球网络安全报告显示&#xff0c;针对3389端口的暴力破解尝试占所有…...

别再只搜字符串了!x64dbg逆向破解卡密软件的另一种思路:从API断点MessageBoxW开始

逆向工程实战&#xff1a;突破字符串搜索局限的API断点追踪法 在逆向分析领域&#xff0c;字符串搜索常被视为破解卡密验证的"第一板斧"。但当你面对一个精心设计的商业软件时&#xff0c;这招往往会失灵——字符串被混淆、关键提示信息被加密、甚至整个代码段都被加…...

Windows Android兼容环境部署指南:跨平台运行的技术实现与实践

Windows Android兼容环境部署指南&#xff1a;跨平台运行的技术实现与实践 【免费下载链接】WSA-Windows-10 This is a backport of Windows Subsystem for Android to Windows 10. 项目地址: https://gitcode.com/gh_mirrors/ws/WSA-Windows-10 在数字化办公与开发场景…...

破局迷茫:Java 2026行业前瞻、零基础通关路径与理科大学生职业跃迁全攻略

你是否正站在人生的十字路口&#xff0c;被一连串的问题反复拷问&#xff1a;听过Java的大名&#xff0c;却始终搞不懂它到底是什么、能支撑你走多远&#xff1f;想入门编程&#xff0c;却面对海量资料无从下手&#xff0c;怕走弯路、怕投入时间最终竹篮打水&#xff1f;刷到无…...

OpenClaw技能扩展实战:用Qwen3-14B镜像自动生成技术文档

OpenClaw技能扩展实战&#xff1a;用Qwen3-14B镜像自动生成技术文档 1. 为什么需要自动化文档生成 作为一个经常需要编写技术文档的开发者&#xff0c;我长期被两个问题困扰&#xff1a;一是文档写作耗时太长&#xff0c;二是维护成本太高。每次代码更新后&#xff0c;文档版…...

VLA边缘认知系统:Deepoc开发板让除草机器人懂农艺会决策

在智慧农业的发展进程中&#xff0c;农田除草自动化始终受困于田间环境的动态多变与农艺需求的灵活多样&#xff0c;传统预设程序的作业模式&#xff0c;难以应对苗草混杂、地块多变、突发障碍等复杂场景。Deepoc具身模型开发板凭借内置的**VLA&#xff08;视觉-语言-动作&…...

PHP爬虫框架大比拼

PHP 爬虫框架介绍PHP 作为服务器端脚本语言&#xff0c;在爬虫领域有多个成熟的框架&#xff0c;以下是主流框架的对比分析&#xff1a;1. Goutte特点&#xff1a;基于 Symfony 组件&#xff0c;轻量易用&#xff0c;适合基础爬取任务。 核心功能&#xff1a;模拟浏览器行为&am…...

LN2407 PWM/PFM 控制 DC-DC 降压稳压器

■ 产品概述 LN2407 是一款由基准电压源、振荡电路、比较器、PWM/PFM 控制电路等构成的 CMOS 降压 DC/DC 调整器。利用 PWM/PFM 自动切换控制电路达到可调占空比&#xff0c;具有全输入电压范围&#xff08;2.0&#xff0d;6V&#xff09;内的低纹波、高效率和大输出电流等特点…...

重塑Obsidian代码块体验:从功能增强到知识管理升级

重塑Obsidian代码块体验&#xff1a;从功能增强到知识管理升级 【免费下载链接】obsidian-better-codeblock Add title, line number to Obsidian code block 项目地址: https://gitcode.com/gh_mirrors/ob/obsidian-better-codeblock 突破笔记局限&#xff1a;代码块美…...