首页 > Web开发 > 详细

[Web] 取消Promise

时间:2019-12-09 23:14:25      阅读:110      评论:0      收藏:0      [点我收藏+]

转载自 为Promise插上可取消的翅膀

const makeCancelable = (promise) => {
  let hasCanceled_ = false;
  const wrappedPromise = new Promise((resolve, reject) => {
    promise.then((val) =>
      hasCanceled_ ? reject({isCanceled: true}) : resolve(val)
    );
    promise.catch((error) =>
      hasCanceled_ ? reject({isCanceled: true}) : reject(error)
    );
  });
  return {
    promise: wrappedPromise,
    cancel() {
      hasCanceled_ = true;
    },
  };
}; 

  

//调用
const somePromise = new Promise(r => setTimeout(r, 1000));//创建一个异步操作
const cancelable = makeCancelable(somePromise);//为异步操作添加可取消的功能
cancelable
  .promise
  .then(() => console.log(‘resolved‘))
  .catch(({isCanceled, ...error}) => console.log(‘isCanceled‘, isCanceled));
// 取消异步操作
cancelable.cancel();  

  

[Web] 取消Promise

原文:https://www.cnblogs.com/0616--ataozhijia/p/12013618.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!