Typescript обещает весь смешанный массив и оператор распространения

У меня есть обещание со смешанным массивом, и я использую оператор распространения, чтобы разделить выходные данные на 2 переменные, первая как IUnpackedFile, а остальные как IDescriptionBody[]. Способ, который я решил, - приведение двух переменных с использованием ключевого слова as. Код ниже:

    return Promise.all<IUnpackedFile | IDescriptionBody>([
      unpackFromHttp("/data/withTexture/5782622127702409215.dat"),
      ...texturePromises
    ])
  .then(([bufferArray, ...rest]) => {
    // casting here
    const description = (rest as IDescriptionBody[]).reduce(
      (res, val) => {
        res[val.CellId] = val;
        return res;
      },
      {} as IDescription
    );

    const meshMaterials = extractMesh(
      // casting here
      (bufferArray as IUnpackedFile).result,
      description
    );

Почему я не могу набрать приведение вывода с использованием кортежа?

then(([bufferArray, ...rest]: [IUnpackedFile , IDescriptionBody[]])

Это ошибка, которую я получаю:

Argument of type '([bufferArray, ...rest]: [IUnpackedFile, IDescriptionBody[]]) => void' is not assignable to parameter of type '((value: (IDescriptionBody | IUnpackedFile)[]) => void | PromiseLike<void>) | null | undefined'.
  Type '([bufferArray, ...rest]: [IUnpackedFile, IDescriptionBody[]]) => void' is not assignable to type '(value: (IDescriptionBody | IUnpackedFile)[]) => void | PromiseLike<void>'.
    Types of parameters '__0' and 'value' are incompatible.
      Type '(IDescriptionBody | IUnpackedFile)[]' is not assignable to type '[IUnpackedFile, IDescriptionBody[]]'.
        Property '0' is missing in type '(IDescriptionBody | IUnpackedFile)[]'.

РЕДАКТИРОВАТЬ: до сих пор я нашел это: Предложение: Вариативные виды По сути, это предложение, которое обсуждается с 30 октября 2015 года.

1 ответ

Почему я не могу набрать приведение вывода с использованием кортежа?

Потому что вы не можете привести массив к кортежу. Вот тот же код, показанный ниже:

declare const foo: number[];
const bar: [number, number] = foo; // Error: property `0` is missing

Больше

Вы на самом деле не наложения типов. Просто присвоение, которое дает вам ошибку, такую ​​же, как в примере, который я показал. Утверждение типа фактически исправит это:

declare const foo: number[];
const bar: [number, number] = foo as [number, number]; // OK
Другие вопросы по тегам