首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用类的方法在typescript中创建联合类型

使用类的方法在typescript中创建联合类型
EN

Stack Overflow用户
提问于 2019-01-08 20:28:07
回答 1查看 182关注 0票数 0

我正在查看一些遗留代码,它们将所有redux缩减程序创建为一个类的实例方法:

代码语言:javascript
复制
@Injectable()
export class PeopleActions {
    constructor(private ngRedux: NgRedux<any>) {}

    add() {
      this.ngRedux.dispatch({ADD, payload: {foo: 'bar;});
    }

    remove() {
      this.ngRedux.dispatch({Remove, payload: {foo: 'bar;});
    }
    // etc.

我通常会将它们创建为单独的函数

代码语言:javascript
复制
export function add { // etc.}
export function remove { // etc.}

然后创建一个联合:

代码语言:javascript
复制
type MyActions = add | remove;

我能以某种方式创建类实例方法的联合吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-01-08 20:36:55

如果您想要类型中所有键的联合,可以使用keyof

代码语言:javascript
复制
type MyActions = keyof PeopleActions; // "add" | "remove"

如果该类还具有不是方法的公共字段,并且您希望过滤掉这些字段,则可以使用条件类型:

代码语言:javascript
复制
type ExtractFunctionKeys<T> = { [P in keyof T]-?: T[P] extends Function ? P : never}[keyof T]
type MyActions = ExtractFunctionKeys<PeopleActions>; // "add" | "remove"
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54091828

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档