π Search Terms
nullish, strictNullChecks, equals, undefined, null
β
Viability Checklist
β Suggestion
When strictNullChecks are enabled, disallow == and === comparisons to null/undefined for expressions that are syntactically known to not be undefined.
I'd imagine the definition of syntactically not null/undefined expressions would be similar to that from #59217.
This is similar to #11920, but I think would be easier to land because it won't error on defensive programming null checks.
π Motivating Example
TypeScript's typeof operator always returns a string, but it can be hard to spot the difference between checking "undefined" and just undefined in code like this:
if (typeof foo === undefined) {
In strictNullChecks mode, TypeScript will catch unnecessary comparisons like this, for expressions that at runtime it knows can never be null or undefined.
π» Use Cases
- What do you want to use this for? catch user errors
- What shortcomings exist with current approaches? there's the https://typescript-eslint.io/rules/no-unnecessary-condition/, but that's type-based so does have the problem of flagging defensive programming. it's also nice to have things be in the compiler instead of a separate tool.
- What workarounds are you using in the meantime? nothing at the moment, if this is infeasible will probably create a custom lint check.
π Search Terms
nullish, strictNullChecks, equals, undefined, null
β Viability Checklist
β Suggestion
When strictNullChecks are enabled, disallow
==and===comparisons to null/undefined for expressions that are syntactically known to not be undefined.I'd imagine the definition of syntactically not null/undefined expressions would be similar to that from #59217.
This is similar to #11920, but I think would be easier to land because it won't error on defensive programming null checks.
π Motivating Example
TypeScript's
typeofoperator always returns a string, but it can be hard to spot the difference between checking"undefined"and justundefinedin code like this:In strictNullChecks mode, TypeScript will catch unnecessary comparisons like this, for expressions that at runtime it knows can never be null or undefined.
π» Use Cases