57 lines
1.4 KiB
Plaintext
Raw Normal View History

== Why is this an issue?
2021-05-29 01:19:26 +00:00
Arrays in JavaScript have several methods for filtering, mapping, or folding that require a callback. Not having a return statement in such a callback function is most likely a mistake, because processing of the array uses the return value of the callback. If there is no return, callback will implicitly return ``++undefined++``, which will likely fail.
2021-04-28 16:49:39 +02:00
This rule applies for the following methods of an array:
* ``++Array.from++``
* ``++Array.prototype.every++``
* ``++Array.prototype.filter++``
* ``++Array.prototype.find++``
* ``++Array.prototype.findIndex++``
* ``++Array.prototype.map++``
* ``++Array.prototype.reduce++``
* ``++Array.prototype.reduceRight++``
* ``++Array.prototype.some++``
* ``++Array.prototype.sort++``
=== Noncompliant code example
2021-04-28 16:49:39 +02:00
2022-02-04 17:28:24 +01:00
[source,javascript]
2021-04-28 16:49:39 +02:00
----
2021-05-29 01:19:26 +00:00
let arr = ["a", "b", "c"];
let merged = arr.reduce(function(a, b) {
2021-04-28 16:49:39 +02:00
a.concat(b);
2021-05-29 01:19:26 +00:00
}); // Noncompliant: No return statement, will result in TypeError
2021-04-28 16:49:39 +02:00
----
=== Compliant solution
2021-04-28 16:49:39 +02:00
2022-02-04 17:28:24 +01:00
[source,javascript]
2021-04-28 16:49:39 +02:00
----
2021-05-29 01:19:26 +00:00
let arr = ["a", "b", "c"];
let merged = arr.reduce(function(a, b) {
2021-04-28 16:49:39 +02:00
return a.concat(b);
2021-05-29 01:19:26 +00:00
}); // merged === "abc"
2021-04-28 16:49:39 +02:00
----
ifdef::env-github,rspecator-view[]
'''
== Implementation Specification
(visible only on this page)
include::message.adoc[]
'''
== Comments And Links
(visible only on this page)
include::comments-and-links.adoc[]
endif::env-github,rspecator-view[]