-
Notifications
You must be signed in to change notification settings - Fork 12.6k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Destructuring array, ability to explicitly tell the variable is unused #31388
Comments
Additional rationale to support this:
|
I agree with this and think all underscore prefixed variables should be ignored by the compiler. This is very confusing for people coming from Go or Rust who are used to being able to ignore any unused variable, not just destructured parameter variables, and it's a much better DX. I personally just spent about an hour trying to figure out why this wasn't working. This is what I'm having to do to destructure an array: const [Input, /* state */ , /* actions */, meta] = input because I want to show what those variables are, even if I don't want to use them. If I want to use them later, it's easier to remember what they are. It would be much cleaner to simply have const [Input, _state , _actions, meta] = input and if I decided I wanted to use them, I just have to remove the underscore (and vice versa). |
Please implement this. We have disabled unused local vars ts 6133 because one of our core async libraries uses tuples instead of objects. Here's a bit more concrete example |
I'd also like this. I come from Rust exactly as @zwhitchcox mentions, and was wondering why the compiler is yelling at me for having unused underscored variables in the middle of a 8-element destructured tuple. Moreover, I feel like with the addition of Variadic Tuple Types in Typescript 4 tuples are going to find much more use, as that is exactly why I have an 8-element typed tuple in the first place - it's constructed by a builder and correctly typed thanks to variadic type parameters. |
I would also like this feature as well |
Seems reasonable, we'd take a PR on this! |
Search Terms
Suggestion
When you're destructuring an array, I want some variables/const to be declared but explicitly make them unused. Typescript has a feature of underscoring the unused parameters for functions:
But it doesn't work for array destruction:
The motivation of the current behavior is that you can destruct array like this:
But you can't do this (this is invalid syntax):
But whatever syntax is valid, what I say is that the ability to explicitly say a variable is unused, with leading underscore - it's good practice, it's convenient, and it should be supported when destructuring arrays, not in functions only.
P.S. Originally I've described the issue here - #31357, but it's wrongly described as a "bug request", so here's a feature request
Use Cases
Today you make some changes to the code that don't require such a variable, so you don't construct it from the array. You had a perfectly named variable, but you remove it. Tomorrow's programmer needs that variable, but he gives it a different name. Of course, there's code review, etc., so eventually it will get a proper name again - it just adds additional communication which is not needed, consumes time which could be used to something more useful.
Additionally, this syntax looks very weird (don't you think?):
Instead, it's much better to have this:
Examples
Having this code:
To receive no errors from typescript when
noUnusedLocals
is set to true.Checklist
My suggestion meets these guidelines:
The text was updated successfully, but these errors were encountered: