+
95
-

回答

在 TypeScript 中,`PromiseLike` 是一个用于表示类似于 Promise 的对象的接口。它用于描述那些具有 `then` 方法的对象,即具有类似 Promise 的 thenable 特性。

`PromiseLike` 接口的定义如下:

interface PromiseLike<T> {
then<TResult1 = T, TResult2 = never>(
onfulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | null | undefined,
onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined
): PromiseLike<TResult1 | TResult2>;
}
`PromiseLike` 接口包含一个 `then` 方法,其参数和返回值与 Promise 的 `then` 方法相似。`then` 方法接受两个可选的回调函数参数,分别用于处理 Promise 的成功和失败状态。返回值是一个新的 `PromiseLike` 对象。这使得具有 `PromiseLike` 特性的对象可以与原生的 Promise 对象一起使用,从而兼容 Promise 的链式调用。举个例子,一个实现了 `PromiseLike` 的简单对象可能如下所示:
class MyPromiseLike<T> implements PromiseLike<T> {
private value: T;

constructor(value: T) {
this.value = value;
}

then<TResult1 = T, TResult2 = never>(
onfulfilled?: ((value: T) => TResult1 | PromiseLike<TResult1>) | null | undefined,
onrejected?: ((reason: any) => TResult2 | PromiseLike<TResult2>) | null | undefined
): PromiseLike<TResult1 | TResult2> {
try {
const result = onfulfilled ? onfulfilled(this.value) : this.value;
return Promise.resolve(result);
} catch (error) {
return Promise.reject(error);
}
}
}

const myPromise = new MyPromiseLike<number>(42);

myPromise
.then(value => value * 2)
.then(result => console.log(result)) // 输出 84
.catch(error => console.error(error));

这个简单的 `MyPromiseLike` 类实现了 `PromiseLike` 接口,使得它可以在链式调用中与原生 Promise 一起使用。

网友回复

我知道答案,我要回答