我用打字稿编写的函数promiseRace中的数据类型有问题。function isPromiseLike<T>(U: T | Promise<T>): U is Promise<T> { return (U as any).then}function promiseRace<T>(values: Array<T | Promise<T>>): Promise<Array<T>> { const isArrayEmpty: boolean = Array.isArray(values) && values.length === 0 return new Promise((resolve, reject) => { if (isArrayEmpty) resolve([]) const promises = values.map((v) => (isPromiseLike(v) ? v : Promise.resolve(v))) promises.forEach((promise) => { if (promise instanceof Promise) { promise.then((data) => resolve(data)).catch((error) => reject(error)) } }) })}排队promise.then((data) => resolve(data)).catch((error) => reject(error))第二个数据带有下划线,我遇到了一个问题:“T”类型的参数不可分配给“T[] | 类型的参数” PromiseLike<T[]> | 不明确的'。类型“T”不可分配给类型“T[]”.ts(2345)。当我做promise.then((data: any) => resolve(data)).catch((error) => reject(error))一切看起来都很好,但这对我来说不是一个好的解决方案。我也想这样做return new Promise<Promise<T>>((resolve, reject) => {但是我把所有的功能都加了下划线:P
2 回答
眼眸繁星
TA贡献1873条经验 获得超9个赞
假设您的代码在第一个承诺成功完成时尝试解析承诺数组,您需要更改代码以使用数据数组调用 resolve 方法。这是因为你返回的承诺有一个承诺数组的通用参数,取自你的 PromiseRace 函数的返回类型,所以它的 resolve 方法期望一个数组作为它的参数。
promise.then((data) => resolve([data])).catch((error) => reject(error))
如果你采纳上面 Dane 的建议,这似乎是一个很好的建议,并且你将返回类型更改为Promise<T>
那么你只需要将空返回条件更改为不返回数组
if (isArrayEmpty) resolve()
千巷猫影
TA贡献1829条经验 获得超7个赞
您实际上不需要 function isPromiseLike
,您的promiseRace
function 可以接受values: Array<T>
然后通过调用 map over it Promise.resolve
。它的行为与您在原始帖子中的行为完全一样。
查看此帖子以获取详细说明: https://stackoverflow.com/a/27746324/5644120
添加回答
举报
0/150
提交
取消