Microsoft/TypeScript
View on GitHubDOM: `Element#matches()` incorrectly narrows types
Open
#63497 opened on May 20, 2026
Domain: lib.d.tsHelp Wanted
Description
🔎 Search Terms
element matches narrow never
🕗 Version & Regression Information
- This changed between versions 5.9.3 and 6.0.3
⏯ Playground Link
💻 Code
declare let element: HTMLElement;
!element.matches( 'dt' ) && element.matches( 'dd' )
🙁 Actual behavior
element.matches( 'dd' ) throws a Property 'matches' does not exist on type 'never' compilation error.
🙂 Expected behavior
element.matches( 'dd' ) does not throw any error.
Additional information about the issue
element.matches( 'dt' ) uses the following overload:
matches<K extends keyof HTMLElementTagNameMap>(selectors: K): this is HTMLElementTagNameMap[K];
The return type of element.matches( 'dt' ) is then this is HTMLElementTagNameMap['dt'] that maps to this is HTMLElement.
Since this is HTMLElement:
- When false, the type of
elementisHTMLElement(not narrowed further). - When false, the type of
elementisnever.