ES6 Array Destructuring Anomaly
In ES6, array destructuring allows for convenient assignment of array elements to variables. However, an unexpected behavior occurs when destructuring without proper use of semicolons.
Consider the following code:
<code class="js">let a, b, c [a, b] = ['A', 'B'] [b, c] = ['BB', 'C'] console.log(`a=${a} b=${b} c=${c}`)</code>
Expected Output:
Actual Output:
Explanation
The unexpected behavior arises from the absence of semicolons between the two destructuring statements. In ES6, semicolons are not automatically inserted. Therefore, the code is parsed as one large statement:
<code class="js">let a = undefined, b = undefined, c = undefined; [a, b] = (['A', 'B'] [(b, c)] = ['BB', 'C']); console.log(`a=${a} b=${b} c=${c}`);</code>
In this statement, the comma operator evaluates to the last expression in the parenthesis, which is the assignment of the array ['BB', 'C'] to the left-hand side (b, c). As a result, b receives 'BB' and c receives 'C'.
However, the second destructuring assignment is incorrectly assigned to the empty array literal ([]) instead of the array ['BB', 'C']. This is because the array literal is enclosed in parentheses without a semicolon at the start of the line.
To resolve this issue, use semicolons to separate the individual assignments:
<code class="js">let a, b, c; [a, b] = ['A', 'B']; [b, c] = ['BB', 'C']; console.log(`a=${a} b=${b} c=${c}`);</code>
With the proper use of semicolons, the expected output is obtained.
The above is the detailed content of ES6 Array Destructuring Anomaly: Why Are Semicolons Important?. For more information, please follow other related articles on the PHP Chinese website!