如何将string转换为在TypeScript中枚举?
我在TypeScript中定义了下面的枚举?
enum Color{ Red, Green }
现在在我的函数中,我接收颜色作为string。 我试过下面的代码。
var green= "Green"; var color : Color = <Color>green; // Error: can't convert string to enum
如何将该值转换为枚举?
TypeScript 0.9中的枚举是基于string+数字的。 你不需要简单的转换types断言:
enum Color{ Red, Green } // To String var green: string = Color[Color.Green]; // To Enum / number var color : Color = Color[green];
在线试用
我在我的OSS书中有关于这个和其他Enum模式的文档: https : //basarat.gitbooks.io/typescript/content/docs/enums.html
这个笔记涉及basarat的答案 ,而不是原来的问题。
我在自己的项目中遇到了一个奇怪的问题,那就是编译器给出的错误大致相当于“不能将string转换为颜色”,使用相当于下面的代码:
var colorId = myOtherObject.colorId; // value "Green"; var color: Color = <Color>Color[colorId]; // TSC error here: Cannot convert string to Color.
我发现编译器types推理变得困惑,它认为colorId
是一个枚举值,而不是一个ID。 要解决这个问题,我必须把ID作为一个string:
var colorId = <string>myOtherObject.colorId; // Force string value here var color: Color = Color[colorId]; // Fixes lookup here.
我不确定是什么导致了这个问题,但我会留下这个笔记,以防万一有人遇到同样的问题。
在Typescript 2.1中,枚举中的string键是强types的。 keyof typeof
用于获取有关可用string键( 1 )的信息:
enum Color{ Red, Green } let typedColor: Color = Color.Green; let typedColorString: keyof typeof Color = "Green"; // Error "Black is not assignable ..." (indexing using Color["Black"] will return undefined runtime) typedColorString = "Black"; // Error "Type 'string' is not assignable ..." (indexing works runtime) let letColorString = "Red"; typedColorString = letColorString; // Works fine typedColorString = "Red"; // Works fine const constColorString = "Red"; typedColorString = constColorString // Works fine (thanks @SergeyT) let letColorString = "Red"; typedColorString = letColorString as keyof typeof Color; typedColor = Color[typedColorString];
https://www.typescriptlang.org/docs/handbook/advanced-types.html#index-types
得到它使用下面的代码工作。
var green= "Green"; var color : Color= <Color>Color[green];
我也遇到了相同的编译器错误。 Sly_cardinal的方法稍微变化一点。
var color: Color = Color[<string>colorId];
如果您确定inputstring与Color枚举完全匹配,请使用:
const color: Color = (<any>Color)["Red"];
在inputstring可能与Enum不匹配的情况下使用:
const mayBeColor: Color | undefined = (<any>Color)["WrongInput"]; if(mayBeColor !== undefined){ //TSC will understand that mayBeColor of type Color here }
操场
如果我们不将enum
为<any>
types,那么tsc将显示错误
元素隐式具有“任何”types,因为索引expression式不是“数字”types。
这意味着默认TS Enumtypes与数字索引一起工作,即let c = Color[0]
,而不是像let c = Color["string"]
这样的string索引。 对于更一般的问题Object string索引,这是Microsoft团队已知的限制。
如果打字稿编译器知道variables的types是string比这个工作
let colorName : string = "Green"; let color : Color = Color[colorName];
否则你应该明确地将其转换为string(以避免编译器警告)
let colorName : any = "Green"; let color : Color = Color["" + colorName];
在运行时,两种解决scheme都可以工