52 lines
1.1 KiB
Plaintext
52 lines
1.1 KiB
Plaintext
ECMAScript 2015 introduced the ability to extract and assign multiple data points from an object or array simultaneously. This is called "destructuring", and it allows you to condense boilerplate code so you can concentrate on logic.
|
|
|
|
|
|
This rule raises an issue when multiple pieces of data are extracted out of the same object or array and assigned to variables.
|
|
|
|
|
|
== Noncompliant Code Example
|
|
|
|
----
|
|
function foo (obj1, obj2, array) {
|
|
var a = obj1.a; // Noncompliant
|
|
var b = obj1.b;
|
|
|
|
var name = obj2.name; // ignored; there's only one extraction-and-assignment
|
|
|
|
var zero = array[0]; // Noncompliant
|
|
var one = array[1];
|
|
}
|
|
----
|
|
|
|
|
|
== Compliant Solution
|
|
|
|
----
|
|
function foo (obj1, obj2, array) {
|
|
var {a, b} = obj1;
|
|
|
|
var {name} = obj2; // this syntax works because var name and property name are the same
|
|
|
|
var [zero, one] = array;
|
|
}
|
|
----
|
|
|
|
|
|
|
|
ifdef::env-github,rspecator-view[]
|
|
|
|
'''
|
|
== Implementation Specification
|
|
(visible only on this page)
|
|
|
|
include::message.adoc[]
|
|
|
|
include::highlighting.adoc[]
|
|
|
|
'''
|
|
== Comments And Links
|
|
(visible only on this page)
|
|
|
|
include::comments-and-links.adoc[]
|
|
endif::env-github,rspecator-view[]
|