中断Promise

Promise 有个缺点就是一旦创建就无法取消,所以本质上 Promise 是无法被终止的,但我们在开发过程中可能会遇到下面两个需求:

中断调用链

就是在某个 then/catch 执行之后,不想让后续的链式调用继续执行了,即:

somePromise
  .then(() => {})
  .then(() => {
    // 终止 Promise 链,让下面的 then、catch 和 finally 都不执行
  })
  .then(() =>console.log('then'))
  .catch(() =>console.log('catch'))
  .finally(() =>console.log('finally'))
复制代码

答案就是在 then/catch 的最后一行返回一个永远 pending 的 promise 即可:

returnnewPromise((resolve, reject) => {})
复制代码

这样的话后面所有的 then、catch 和 finally 都不会执行了。

中断Promise

注意这里是中断而不是终止,因为 Promise 无法终止,这个中断的意思是&#x

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中,Promise是用于管理异步操作的重要工具之一。然而,有时我们可能需要中断一个Promise链的执行。有几种方法可以实现这个目标。 一种方法是使用自定义的异常来抛出中断信号。你可以定义一个BreakSignal类作为中断的信号,然后在想要中断的地方使用throw关键字抛出BreakSignal异常。然后,在Promise链的后续部分使用catch方法来捕获BreakSignal异常并执行相应的处理逻辑。这样,当中断信号被抛出时,Promise链的执行将会被中断。 另一种方法是使用第三方库或自己实现的Promise库,其中包含了类似于Promise.break的特殊语法来中断Promise链的执行。在这种情况下,你可以使用类似于Promise.break的语法来直接中断Promise链的执行。具体的实现方法可能因使用的库而有所不同,但基本思路是使用类似于break的语法来中断Promise链的执行。 无论你选择哪种方法,中断Promise链的关键是在适当的地方抛出一个信号或使用特殊的语法来终止Promise链的执行。然后,你可以根据需要在后续部分进行相应的处理。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [中断promise](https://blog.csdn.net/qq_24147051/article/details/108049705)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值