-
Notifications
You must be signed in to change notification settings - Fork 3.5k
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
Update Coding Guide with notes on destructuring assignment #12196
Comments
Personally I'm a fan of destructuring everywhere it makes sense. I don't think it's main benefit is default values though. I'll also mention #11674 just to crosslink related issues. |
Rather than putting this in the coding guide, this should be enforced through eslint: https://eslint.org/docs/latest/rules/prefer-destructuring |
Are there any performance implications to using destructuring assignment everwhere? |
Regarding the handling of Regarding the performance: There are some claims, but ... these are soooo 2018 (i.e. it's hard to measure that objectively across browsers and JITs). Regarding the eslint: But... highly subjective: I'm not sure about enforcing that particular rule. Destructuring assignment can be convenient when you really just have an object with 10 properties and want to pull out these 10 properties as local variables. But in some cases, the syntax is really obscure. For example, consider something like
Now, that innocent, bread-and-butter, self-explanatory last line would be flagged by eslint. It should actually be written as |
I was going to call out that specific example too, that looks awful to me. I think there's merit for at least a mention of destructuring in the coding guide as a suggestion "where it makes sense to do so" but I'm not sure I like the way eslint may choose to enforce it. Most of the time I think it's a subjective thing on a case by case basis of whatever makes the code more readable. On performance, I have never seen anything mentioned that one is better or worse. I'd assume with how long it's been around most browsers should be able to optimize around both pretty well. That said I haven't done any research into it so I could be wrong. |
As flagged by @javagl in #12188 (review): The current Coding Guide does not discuss destructuring assignment.
Since #10486, many ES6 patterns have naturally found their way into the code, including destructuring assignments. For example,
This syntax is often both more concise and easier to read, compared to the legacy pattern:
This raises 2 questions for the Coding Guide:
defaultValue
? The destructuring default syntax will replaceundefined
with the given default, but will passnull
through.The text was updated successfully, but these errors were encountered: