无法从Promise解析的数据中,无法将类型“ T”分配给类型“ T []”。ts(2345)

时间:2020-09-10 12:43:04

标签: javascript typescript promise

我用打字稿编写的函数 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 []”。ts(2345)。 当我做

promise.then((data: any) => resolve(data)).catch((error) => reject(error))

一切都很好,但这对我来说不是一个好的解决方案。 我也想做这样的事

return new Promise<Promise<T>>((resolve, reject) => {

但是我的所有功能都带有下划线:P

请提供任何帮助!

2 个答案:

答案 0 :(得分:0)

假设第一个promise成功完成时,您的代码正在尝试解析promise数组,则需要更改代码以使用数据数组调用resolve方法。这是因为您返回的Promise具有PromiseRace函数的返回类型的Promise数组的通用参数,因此resolve方法将数组作为其参数。

promise.then((data) => resolve([data])).catch((error) => reject(error))

Playground Link

如果您接受上述Dane的建议,这似乎是一个好建议,并且将返回类型更改为Promise<T>,则只需更改空的返回条件即可不返回数组

if (isArrayEmpty) resolve()

答案 1 :(得分:-1)

您实际上不需要功能isPromiseLike,您的promiseRace函数可以使用values: Array<T>,然后通过调用Promise.resolve在其上进行映射。它的行为将与您在原始帖子中所做的完全一样。

查看此帖子以获取详细说明: https://stackoverflow.com/a/27746324/5644120