取消 promise

借助于 Promise.race() 方法,可以很容易地取消一个 Promise。

function cancelablePromise(promise) {
  let hasCanceled = false;

  const wrappedPromise = new Promise((resolve, reject) => {
    promise.then(
      (val) => (hasCanceled ? reject({ isCanceled: true }) : resolve(val)),
      (error) => (hasCanceled ? reject({ isCanceled: true }) : reject(error))
    );
  });

  return {
    promise: wrappedPromise,
    cancel() {
      hasCanceled = true;
    },
  };
}

const cancelable = cancelablePromise(fetch("http://www.example.com"));

cancelable.promise.then(
  (val) => console.log("request succeeded", val),
  (error) => console.log("request failed", error)
);

// 取消请求
cancelable.cancel();

最后更新于

这有帮助吗?