Helo Stack社区,
我有以下enum
映射类:
export class RestEnumMpapper<T> {
constructor() {}
getEnumAsString<T>(o: T, key: string | number): string {
if (typeof key === 'string') {
return (o as T)[(o as T)[key]];
} else if (typeof key === 'number') {
return (o as T)[key];
} else {
throw new Error(`Unable to parse enum from ${typeof(key)}`);
}
}
/* ... Rest of enum converting class code ... */
}
典型的用例如下:
export class PositionEvent {
private static statusEnumMapper: RestEnumMpapper<EventState> = new RestEnumMpapper<EventState>();
/* ... */
this.status = PositionEvent.statusEnumMapper.getEnumAsString(EventState, iPos.status) as EventState;
}
它工作得很好,但是我目前正在整理我的代码,而linter抱怨这里的T
类中的通用类型RestEnumMpapper
会被遮盖:
export class RestEnumMpapper<T> {
在这里:
getEnumAsString<T>(o: T, key: string | number): string {
这是合理的,并且将通用类型保留为类类型是有意义的。但是,当我在每次调用的函数声明中删除T
时,都会出现TypeScritp
错误:
[ts]类型'EventState'的参数不能分配给'EventState'类型的参数。
可以通过传递枚举值(或任何其他纯数字)来强制工作,但是在尝试解析诸如2[3]
之类的语句时,函数显然会失败。
如果有任何建议解决此问题,我将不胜感激。在将泛型类型放入函数TypeScritp之前,它能够以某种方式将T解析为具有属性的对象,而只需要一个枚举即可。
答案 0 :(得分:2)
之所以会这样,是因为您没有将枚举的值传递给函数,该函数的类型为EventState
,而是将包含枚举的对象的类型为typof EventState
。因此,从方法中删除类型参数,但将typeof EventState
传递给类应该可以正常工作:
let statusEnumMapper = new RestEnumMpapper<typeof EventState>();
我也可能建议,如果似乎是将类绑定到单个枚举,则最好将其传递给构造函数,并向T
添加索引签名以允许在不强制转换的情况下进行索引:
export class RestEnumMpapper<T extends { [name: string]: any }> {
constructor(public enumObject: T) { }
getEnumAsString(key: string | number): string {
if (typeof key === 'string') {
return this.enumObject[this.enumObject[key]];
} else if (typeof key === 'number') {
return this.enumObject[key];
} else {
throw new Error(`Unable to parse enum from ${typeof (key)}`);
}
}
/* ... Rest of enum converting class code ... */
}
enum EventState {
Test = "Test",
One = "One",
}
let statusEnumMapper = new RestEnumMpapper(EventState);
let statusStr = "One";
let status = statusEnumMapper.getEnumAsString(statusStr) as EventState;