Skip to content

'in' does not remove undefined from indexed value (with noUncheckedIndexedAccess)Β #61389

Open
@Sainan

Description

@Sainan

πŸ”Ž Search Terms

in operator, noUncheckedIndexedAccess

πŸ•— Version & Regression Information

Tested 5.8.2 and 5.9.0-dev.20250310

⏯ Playground Link

https://www.typescriptlang.org/play/?noUncheckedIndexedAccess=true&ts=5.8.2#code/MYewdgzgLgBAhgJwQLhmArgWwEYFMEDaAujALwwECMANDAEy0DMRA3AFCiSwCWAJgB6oMOfGXrtuAMxgAKPvxjcw8JAEoYAbzYwdMTtBiC0WPAjGJC81tt36QAG1wA6eyADmM-qvYBfNkA

πŸ’» Code

With an array:

const arr: number[] = [1, 2, 3];
const idx: number = 2;
if (idx in arr) {
    const x: number = arr[idx];
    console.log(x);
}

With a map/object:

const map: Record<string, number> = { a: 1 };
const key: string = "a";
if (key in map) {
    const x: number = map[key];
    console.log(x);
}

πŸ™ Actual behavior

Type 'number | undefined' is not assignable to type 'number'.
  Type 'undefined' is not assignable to type 'number'.

πŸ™‚ Expected behavior

Expected 'in' operator to guarantee that the result of indexing is not undefined in this branch.

Additional information about the issue

No response

Metadata

Metadata

Assignees

No one assigned

    Labels

    Help WantedYou can do thisPossible ImprovementThe current behavior isn't wrong, but it's possible to see that it might be better in some cases

    Type

    No type

    Projects

    No projects

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions