21 lines
774 B
Plaintext
Raw Normal View History

2021-04-28 16:49:39 +02:00
Many of JavaScript's ``++Array++`` methods return an altered version of the array while leaving the source array intact. ``++reverse++`` and ``++sort++`` do not fall into this category. Instead, they alter the source array _in addition to_ returning the altered version, which is likely not what was intended.
This rule raises an issue when the return values of these methods are assigned, which could lead maintainers to overlook the fact that the original value is altered.
== Noncompliant Code Example
----
var b = a.reverse(); // Noncompliant
var d = c.sort(); // Noncompliant
----
== Compliant Solution
----
var b = [...a].reverse(); // de-structure and create a new array, so reverse doesn't impact 'a'
a.reverse();
c.sort(); // this sorts array in place
----