我用打字稿编写的函数 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
promise.then((data: any) => resolve(data)).catch((error) => reject(error))
一切都很好,但这对我来说不是一个好的解决方案。 我也想做这样的事
return new Promise<Promise<T>>((resolve, reject) => {
但是我的所有功能都带有下划线:P
请提供任何帮助!
答案 0 :(得分:0)
假设第一个promise成功完成时,您的代码正在尝试解析promise数组,则需要更改代码以使用数据数组调用resolve方法。这是因为您返回的Promise具有PromiseRace函数的返回类型的Promise数组的通用参数,因此resolve方法将数组作为其参数。
promise.then((data) => resolve([data])).catch((error) => reject(error))
如果您接受上述Dane的建议,这似乎是一个好建议,并且将返回类型更改为Promise<T>
,则只需更改空的返回条件即可不返回数组
if (isArrayEmpty) resolve()
答案 1 :(得分:-1)
您实际上不需要功能isPromiseLike
,您的promiseRace
函数可以使用values: Array<T>
,然后通过调用Promise.resolve
在其上进行映射。它的行为将与您在原始帖子中所做的完全一样。
查看此帖子以获取详细说明: https://stackoverflow.com/a/27746324/5644120