-
-
Notifications
You must be signed in to change notification settings - Fork 381
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
consistent-destructuring
improvements
#1005
Comments
Another improvement, imo, would be to allow referencing a higher property that was deeply destructured: const {request: {cache, mode, url}} = e;
doSomething(cache, mode, url);
doAnother(e.request); |
Another improvement, aim at Vue@3.0,It's no longer responsive when you deconstruct it <script>
import { defineComponent, watch } from 'vue'
export default defineComponent({
name: 'Hello',
setup(props, context) {
const { a, b, c } = props
if (a && b && c) {
// TODO
}
watch(() => props.a, () => {})
watch(() => props.d, () => {})
}
})
</script> |
asyncRequest(result => {
const { a, b, c, d = [] } = result
const e = result.e || []
// The value of d and e is different
}) |
// @medusalix @nickofthyme @MrHen @futpib Mentioning you from the original issue for the rule in case you have any thoughts on these possible improvements. |
// @zloirock @brettz9 @GuoSirius Can you take a look my new proposal #1230, I think this is more like you want. |
Regarding your Vue case, @GuoSirius , I think that could be met by https://eslint.vuejs.org/rules/no-setup-props-destructure.html . |
I think examples provided here can be rewritten in a better way that does conform to the latest (31.0.0) unicorn rules: @zloirock's from #1005 (comment): let {chrome, ie, safari, edge} = module;
if (!edge && ie) {
edge = '12';
}
if (!edge) {
// ...
}
// If you *really* need to mutate `module.edge` for some reason,
// do it after you changed all destructured variables you wanted to change:
Object.assign(module, {
chrome,
ie,
safari,
edge,
}); if (Object.getPrototypeOf(object) === Object.prototype) {
// ...
} @brettz9's from #1005 (comment) This already passes unicorn rules, but you could rewrite it to use even more destructuring with IMO even better readability: const {request} = event;
const {cache, mode, url} = request;
doSomething(cache, mode, url);
doAnother(request); I don't get exactly which improvements are proposed here. I think this needs more clear examples with comments like "This line is reported (and/or autofixed) but I think it should not be reported" or "This line is not reported but I think it should be reported (and/or autofixed)" each in a separate issue. Even better, if you feel like it, write a failing test for maximum clarity. |
Yes, they can be redone, but some of us consider it troublesome to have to refactor, e.g., changing |
I might just add that I think there are essentially three approaches that are favored, none of which is necessarily superior, but the current rule only allows one of them.
By my own preference, I mean the following: const {a, b, c: {d}} = obj
obj.c // Should *not* report since it would require retooling (a new line)
if (!obj.f) { // Should *not* report as it would require retooling (replacing
// with `let` or a `let` and `const`)
obj.f = '12';
}
obj.e // Should report since it can just be added to the destructuring |
It could be good to add an option for ignoring redefined properties of sources:
It could be good to add an option to ignore some sources or properties:
The text was updated successfully, but these errors were encountered: