Géppel nem lehet végrehajtani generikus függvény felületén

szavazat
0

Próbálom, hogy végre egy generikus függvény felületén, és nem tudom, hogy működik.

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');
};

Itt van egy screenshot tokenMapper.ts, mondván IToken import használt, de kellett volna egy hasznát:

tokenMapper.ts

Edit: A géppel 3.0.3

A kérdést 19/09/2018 13:20
a forrás felhasználó
Más nyelveken...                            


2 válasz

szavazat
4

Úgy vélem, akkor megvalósítja a gépelés egy általános felületet 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');
};

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

Válaszolt 19/09/2018 13:38
a forrás felhasználó

szavazat
1

Tehát itt van, amit változott, hogy ez a munka

ITokenMapper.ts -> IMapper.ts átnevezett és frissített

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

tokenMapper.ts -> abpTokenMapper.ts átnevezett és frissített

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');
};

Válaszolt 20/09/2018 07:43
a forrás felhasználó

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