我的编程空间,编程开发者的网络收藏夹
学习永远不晚

VuePromise解决回调地狱问题实现方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

VuePromise解决回调地狱问题实现方法

问题

首先,什么是回调地狱:

  • 层嵌套的问题。
  • 每种任务的处理结果存在两种可能性(成功或失败),那么需要在每种任务执行结束后分别处理这两种可能性。

当一个接口需要依赖另一个接口的请求数据时,通常有两种解决方式

  • 将请求数据的接口设为同步,之后调另一个接口
  • 在请求数据接口的成功回调里调另一个接口

这两种问题在回调函数时代尤为突出。Promise 的诞生就是为了解决这两个问题。

典型的高阶函数,将回调函数作为函数参数传给了readFile。但久而久之,就会发现,这种传入回调的方式也存在大坑, 比如下面这样:

fs.readFile('1.json', (err, data) => {
    fs.readFile('2.json', (err, data) => {
        fs.readFile('3.json', (err, data) => {
            fs.readFile('4.json', (err, data) => {
            });
        });
    });
});

回调当中嵌套回调,也称回调地狱。这种代码的可读性和可维护性都是非常差的,因为嵌套的层级太多。而且还有一个严重的问题,就是每次任务可能会失败,需要在回调里面对每个任务的失败情况进行处理,增加了代码的混乱程度。

解决方案

Promise 利用了三大技术手段来解决回调地狱:

  • 回调函数延迟绑定。
  • 返回值穿透。
  • 错误冒泡。

首先来举个例子:

let readFilePromise = (filename) => {
    fs.readFile(filename, (err, data) => {
        if(err) {
            reject(err);
        }else {
            resolve(data);
        }
    })
}
readFilePromise('1.json').then(data => {
    return readFilePromise('2.json')
});

看到没有,回调函数不是直接声明的,而是在通过后面的 then 方法传入的,即延迟传入。这就是回调函数延迟绑定。

然后我们做以下微调:

let x = readFilePromise('1.json').then(data => {
    return readFilePromise('2.json')//这是返回的Promise
});
x.then()

我们会根据 then 中回调函数的传入值创建不同类型的Promise, 然后把返回的 Promise 穿透到外层, 以供后续的调用。这里的 x 指的就是内部返回的 Promise,然后在 x 后面可以依次完成链式调用。

这便是返回值穿透的效果。

这两种技术一起作用便可以将深层的嵌套回调写成下面的形式:

readFilePromise('1.json').then(data => {
    return readFilePromise('2.json');
}).then(data => {
    return readFilePromise('3.json');
}).then(data => {
    return readFilePromise('4.json');
});

这样就显得清爽了许多,更重要的是,它更符合人的线性思维模式,开发体验也更好。

两种技术结合产生了链式调用的效果。

这解决的是多层嵌套的问题,那另一个问题,即每次任务执行结束后分别处理成功和失败的情况怎么解决的呢?

Promise采用了错误冒泡的方式。其实很简单理解,我们来看看效果:

readFilePromise('1.json').then(data => {
    return readFilePromise('2.json');
}).then(data => {
    return readFilePromise('3.json');
}).then(data => {
    return readFilePromise('4.json');
}).catch(err => {
  // xxx
})

这样前面产生的错误会一直向后传递,被catch接收到,就不用频繁地检查错误了。

到此这篇关于Vue Promise解决回调地狱问题实现方法的文章就介绍到这了,更多相关Vue Promise回调地狱内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

VuePromise解决回调地狱问题实现方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

VuePromise解决回调地狱问题实现方法

这篇文章主要介绍了VuePromise解决回调地狱问题,总的来说这并不是一道难题,那为什么要拿出这道题介绍?拿出这道题真正想要传达的是解题的思路,以及不断优化探寻最优解的过程。希望通过这道题能给你带来一种解题优化的思路
2023-01-12

Vue Promise如何解决回调地狱问题

本篇内容介绍了“Vue Promise如何解决回调地狱问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!问题首先,什么是回调地狱:层嵌套的问
2023-07-05

.Net回车符问题的解决方法

今天就跟大家聊聊有关.Net回车符问题的解决方法,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。有关.net回车符的问题在具体开发的过程中是十分常见的,那么如何解决实际的问题是我们经常
2023-06-17

IP地址冲突问题及解决方法

本篇内容主要讲解“IP地址冲突问题及解决方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“IP地址冲突问题及解决方法”吧!如今许多操作以及工作都在网络上流行,那么我们就要注意网络的应用了。伴随着
2023-06-20

Android中Fragment多层嵌套时onActivityResult无法正确回调问题的解决方法

前言:Fragment也可以使用startActivityForResult方法去打开一个Activity,然后在其onActivityResult方法中处理结果,可是当Fragment嵌套的时候,由于FragmentActivity的BU
2022-06-06

java高级用法之JNA中的回调问题怎么解决

今天小编给大家分享一下java高级用法之JNA中的回调问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。简介什么是c
2023-06-30

Discuz删除回复常见问题及解决方法

Discuz删除回复常见问题及解决方法随着社区论坛的发展,Discuz作为一种常用的论坛系统,为用户提供了便捷的交流平台。然而,一些用户在使用Discuz时可能会遇到删除回复的问题,导致困扰。本文将针对Discuz删除回复的常见问题进行讨
Discuz删除回复常见问题及解决方法
2024-03-09

WinXP下IP地址的跟踪问题解决方法

有时候可能因为工作需要或者电脑遭受攻击等时候需要用上跟踪IP地址,跟踪IP地址有时候是必需的,如果你的网络发生问题或者需要改变些设置的时候,这个东西就派上用场了。不过很多用户在需要解决WinXP操作系统的DHCP故障时,有时要找出某个地址范
2023-06-12

解决Python出现_warn_unsafe_extraction问题的方法

在Python项目中运行出现了“AttributeError: ResourceManager instance has no attribute ‘_warn_unsafe_extraction'”问题,研究了一下,发现是setuptoo
2022-06-04

解决SpringBoot的@DeleteMapping注解的方法不被调用问题

这篇文章主要介绍了解决SpringBoot的@DeleteMapping注解的方法不被调用问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2023-01-12

解决常见的回流和重绘问题的方法

常见回流和重绘问题及解决方案,需要具体代码示例在Web开发中,性能优化是一个重要的话题。回流和重绘是Web页面渲染过程中常遇到的性能问题,它们会导致页面的卡顿和资源浪费。本文将介绍常见的回流和重绘问题,并提供一些解决方案,帮助开发者优化页
解决常见的回流和重绘问题的方法
2024-01-26

C++多态性的实现及常见问题解决方法

C++多态性的实现及常见问题解决方法引言:在C++编程中,多态性是一种重要的概念和特性。它允许我们使用基类的指针或引用来操作派生类的对象,从而实现了程序的灵活性和复用性。本文将介绍C++中多态性的实现方式,并探讨一些常见的多态性问题及其解决
2023-10-22

Android应用中clearFocus方法调用无效的问题解决

clearFocus 无效 EditText在focus与非focus的时候,显示效果是不同的:focus的时候光标是闪的,而且我们通常也会给它设置selector,focus的时候给它加上边框之类的. 通常当我们触摸EditText之外的
2022-06-06

CentOS8出现-bash:乱码问题及解决方法

出现这个情况一般是由于没有安装中文语言包,或者设置的默认语言有问题导致的。 查看当前语言环境 echo $LjVSpOnnANG 发现为 zh_TW.UTF-8 但是中文语言jVSpOnn包没安装或没启用,就会出现乱码 输入LANG
2022-06-04

Spring Cloud出现Options Forbidden 403问题解决方法

摘要:本文简述了博主在开发过程中,需要跨域调试的时候,出现了 OPTIONS 请求 Forbidden 的问题,以及解决方法。403 Forbidden 解释:ForbiddenYou don't have permission to ac
2023-05-30

编程热搜

目录