Tapuscrit Impossible de mettre en œuvre l'interface de fonction générique

voix
0

Je suis en train de mettre en œuvre une interface de fonction générique et je ne peux pas le faire fonctionner.

IToken.ts

export interface IToken {
  token: string;
  expires: number;
}

ITokenMapper.ts

export interface ITokenMapper {
  <T>(apiResult: any): T;
}

tokenMapper.ts

import {ITokenMapper} from ./interfaces/ITokenMapper;
import {IToken} from ./interfaces/IToken;

export const tokenMapper: ITokenMapper = function <IToken>(apiResult: any): IToken {
  if(apiResult.token && apiResult.expires) {
    return {token: apiResult.token as string, expires: apiResult.expires as number}
  }
  throw new Error('Unable to parse token');
};

Voici une capture d' écran de tokenMapper.tsdire l' importation itoken est utilisé , mais je devrais avoir un emploi pour lui:

tokenMapper.ts

Edit: En utilisant Tapuscrit 3.0.3

Créé 19/09/2018 à 13:20
source utilisateur
Dans d'autres langues...                            


2 réponses

voix
4

Je crois que vous pouvez accomplir votre frappe avec une interface générique ITokenMapper<T>

interface IToken {
    token: string;
    expires: number;
}

interface ITokenMapper<T> {
    (apiResult: T): T;
}

const tokenMapper: ITokenMapper<IToken> = function (apiResult) {
    if(apiResult.token && apiResult.expires) {
      return { token: apiResult.token as string, expires: apiResult.expires as number};
    }

    throw new Error('Unable to parse token');
};

De: https://www.typescriptlang.org/docs/handbook/generics.html#generic-types

Créé 19/09/2018 à 13:38
source utilisateur

voix
1

Voici donc ce que je l'ai changé pour le faire fonctionner

ITokenMapper.ts -> IMapper.ts renommé et mis à jour

export type IMapper<T> = (apiResult: any) => T;

tokenMapper.ts -> abpTokenMapper.ts renommé et mis à jour

import { IMapper } from "../../utils/IMapper";
import { IToken } from "../interfaces/IToken";

export const abpTokenMapper: IMapper<IToken> = (apiResult: any) => {
  if (apiResult.accessToken && apiResult.expireInSeconds) {
    return { token: apiResult.accessToken as string, expires: apiResult.expireInSeconds as number }
  }
  throw new Error('Unable to parse token');
};

Créé 20/09/2018 à 07:43
source utilisateur

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more