46 lines
1.2 KiB
Plaintext
Raw Normal View History

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++``
2021-04-28 16:49:39 +02:00
== Noncompliant Code Example
----
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
----
2021-04-28 16:49:39 +02:00
== Compliant Solution
----
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[]
'''
== Comments And Links
(visible only on this page)
include::comments-and-links.adoc[]
endif::env-github,rspecator-view[]