-
Notifications
You must be signed in to change notification settings - Fork 13.2k
Open
Labels
In DiscussionNot yet reached consensusNot yet reached consensusSuggestionAn idea for TypeScriptAn idea for TypeScript
Description
Suggestion
🔍 Search Terms
rest spread element destructure destructuring discriminated union narrow refine
✅ Viability Checklist
My suggestion meets these guidelines:
- This wouldn't be a breaking change in existing TypeScript/JavaScript code
- This wouldn't change the runtime behavior of existing JavaScript code
- This could be implemented without emitting different JS based on the types of the expressions
- This isn't a runtime feature (e.g. library functionality, non-ECMAScript syntax with JavaScript output, new syntax sugar for JS, etc.)
- This feature would agree with the rest of TypeScript's Design Goals.
⭐ Suggestion
A natural extension of #46266 would be to support the following
type Action =
| { kind: 'A', payload: number }
| { kind: 'B', payload: string };
function example({ kind, ...rest }: Action) {
if (kind === 'A') {
rest.payload.toFixed();
}
if (kind === 'B') {
rest.payload.toUpperCase();
}
}📃 Motivating Example
💻 Use Cases
SferaDev, mhofman, denk0403, mkantor, jcalz and 72 more
Metadata
Metadata
Assignees
Labels
In DiscussionNot yet reached consensusNot yet reached consensusSuggestionAn idea for TypeScriptAn idea for TypeScript