In TypeScript, I want to compare two variables containing enum values. Here's my minimal code example:
enum E {
A,
B
}
let e1: E = E.A
let e2: E = E.B
if (e1 === e2) {
console.log("equal")
}
When compiling with tsc
(v 2.0.3) I get the following error:
TS2365: Operator '===' cannot be applied to types 'E.A' and 'E.B'.
Same with ==
, !==
and !=
.
I tried adding the const
keyword but that seems to have no effect.
The TypeScript spec says the following:
4.19.3 The <, >, <=, >=, ==, !=, ===, and !== operators
These operators require one or both of the operand types to be assignable to the other. The result is always of the Boolean primitive type.
Which (I think) explains the error. But how can I get round it?
Side note
I'm using the Atom editor with atom-typescript, and I don't get any errors/warnings in my editor. But when I run tsc
in the same directory I get the error above. I thought they were supposed to use the same tsconfig.json
file, but apparently that's not the case.
If was able to compare two enums with this
with ProductTypes being this
export enum ProductTypes{Merchandises,Goods,...}
In typescript an example enum:
is transformed to javascript into this object:
I had many problems with comparison enums in typescript. This simple script solves the problem:
then in javascript, the object is transformed into:
If you don't need to use enums - it's better not to use. Typescript has more advanced types, more here: https://www.typescriptlang.org/docs/handbook/advanced-types.html You can use instead:
There is another way: if you don't want generated javascript code to be affected in any way, you can use type cast:
In general, this is caused by control-flow based type inference. With current typescript implementation, it's turned off whenever function call is involved, so you can also do this:
The weird thing is, there is still no error if the
id
function is declared to return precisely the same type as its agument:The only thing that worked for me (in typescript 2.2.1) was this:
This compares the strings representing the names (eg. "A" and "B").
Well I think I found something that works:
But I'm a bit surprised that this isn't mentioned anywhere in the documentation.
I would define values for Enum like this and compare with
===