繁体   English   中英

我可以为类的方法定义通用的打字稿接口吗?

[英]Can I define a generic typescript Interface for the methods of a Class?

我正在清理Angular 4应用程序的类型,并且想定义一个负责API调用的Database类的接口。

这些类将具有接收Criteria对象并返回ResultItems[]很大的ResultItems[] Observables的ResultItems[] 所以我尝试定义此接口:

import { Observable } from 'rxjs/Observable';

export interface Database<C> {
  [methodName: string]: (args: C) => Observable<any>;
}

涵盖接收Criteria并返回any东西的方法。

然后,我尝试进行这种实现:

@Injectable()
export class ItemsDatabase<ItemsCriteria> implements Database<ItemsCriteria> {
  constructor(private api: ApiService) {}

  fetch(args: ItemsCriteria): Observable<APIResponse[]> {
    return this.api.fetchItems(args);
  }

  summary(args: ItemsCriteria): Observable<SummaryResponse[]> {
    return this.api.itemsSummary(args);
  }
}

但Typescript拒绝抛出:

Class 'ItemsDatabase<ItemsCriteria>' incorrectly implements interface 'Database<ItemsCriteria>'.
  Index signature is missing in type 'ItemsDatabase<ItemsCriteria>'

有什么建议吗? 还是这是不可能的? 提前致谢!

您必须将索引签名添加到类中

@Injectable()
export class ItemsDatabase<ItemsCriteria> implements Database<ItemsCriteria> {
  constructor(private api: ApiService) {}
  [methodName: string]: (args: ItemsCriteria) => Observable<any>;
  fetch(args: ItemsCriteria): Observable<APIResponse[]> {
    return this.api.fetchItems(args);
  }

  summary(args: ItemsCriteria): Observable<SummaryResponse[]> {
    return this.api.itemsSummary(args);
  }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM