export enum MyEnum{
Option1,
Option2,
Option3
}
string x = 'Option1';
MyEnum[x] throws an error:
Type string is not assignable to type MyEnum
however:
MyEnum['Option1'] works.
I need to use MyEnum[x] though (in a method that returns a MyEnum), where x is a calculated value that results in one of the valid enum options, how do I go about it?
There are two elegant ways to achieve this 🚀
⭐️ 1st way: just simply turn off the type checking for the next line, which is similar to asserting the type of MyEnum to <any> as done in the @annepic 's answer
// @ts-ignore
MyEnum[x]
⭐️ 2nd: If u still want to keep the powerful typechecking feature of TS, choose this
MyEnum[x as keyof typeof MyEnum]
typeof MyEnum will create an interface that represents the MyEnum object behind the scene and keyof will return a union of string literals, each one is the key in the MyEnum object (in other words, keyof will return a list of keys of a given object/class).
Extra note: Always turn on the Strict flag in tsconfig no matter what (u should only ignore type checking for a single line in very rare and special cases as done above). This configuration will force the developers to define the shape/type/structure for everything, which makes the entire codebase super self-documenting and self-explanatory, especially for your future self and code maintainers. U can quickly infer how a class/object is structured and how a function is used with 100% certainty without even looking at its implementation. JSDoc specifies a set of very strict formatting rules for documenting JS code using comments, but these comments often end up being out of date because they are not changed along with the function evolution. Other benefits of the Strict flag are mentioned in the TypeScript primary doc.
Got it to work like this: return (<any>MyEnum)[x];
You are declaring your string x variable wrong. You should do this:
export enum MyEnum{
Option1,
Option2,
Option3
}
var x = 'Option1';
MyEnum[x];
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With