matthias
matthias

Reputation: 2062

Typescript implement interface with same keys but different types

I have an interface

export interface Foo {
  a: string;
  b: string;
}

I want to have another class that implements all keys of the interface but in other types:

export class Bar implements keysof(Foo) {
  a: SomeNewType;
  b: SomeNewType2;
}

Is this possible in typescript?

Upvotes: 8

Views: 2143

Answers (1)

Meirion Hughes
Meirion Hughes

Reputation: 26398

You could potentially do it with a key map.

export interface Foo {
  a: string;
  b: string;
}

type HasKeys<T> = {
  [P in keyof T]: any;
}

export class Bar implements HasKeys<Foo> {

}

this will complain that Bar is missing a and b but it will be fine if you define them with any type. i.e.

export class Bar implements HasKeys<Foo> {
  a: number;
  b: object;
}

Upvotes: 10

Related Questions