In JavaScript, the array data type consists of a list of elements. There are many useful built-in methods available for JavaScript developers to work with arrays. Methods that modify the original array are known as mutator methods, and methods that return a new value or representation are known as accessor methods.
There is a third class of array methods, known as iteration methods, which are methods that operate on every item in an array, one at a time. These methods are closely associated with loops. In this tutorial, we will be focusing on iteration methods.
In order to get the most out of this tutorial, you should have some familiarity with creating, indexing, modifying, and looping through arrays, which you can review in the tutorial Understanding Arrays in JavaScript.
In this tutorial, we will use iteration methods to loop through arrays, perform functions on each item in an array, filter the desired results of an array, reduce array items down to a single value, and search through arrays to find values or indices.
Note: Array methods are properly written out as Array.prototype.method()
, as Array.prototype
refers to the Array
object itself. For simplicity, we will simply list the name as method()
.
Many examples throughout this tutorial will be using JavaScript arrow function expressions, which are represented by an equals sign followed by a greater than sign: =>
.
A function is a block of reusable code that can be executed. Traditionally, a function can be written with the following syntax:
var example = function() {
// code to execute
}
example();
The latest version of JavaScript at the time of writing allows for the use of arrow functions, which can be written with the following syntax:
var example = () => {
// code to execute
}
example();
The parentheses in either case may contain parameters. When there is only one parameter, the parentheses can be omitted, as such:
var example = parameter1 => {
// code to execute
}
Throughout the examples in this tutorial, we will use the arrow function syntax. To read and understand more about functions in JavaScript, read the Functions reference on the Mozilla Developer Network.
The forEach()
method calls a function for each element in an array.
Let’s start with the following array assigned to the variable fish
:
let fish = [ "piranha", "barracuda", "cod", "eel" ];
We can use forEach()
to print each item in the fish
array to the console.
// Print out each item in the array
fish.forEach(individualFish => {
console.log(individualFish);
})
Once we do so, we’ll receive the following output:
Outputpiranha
barracuda
cod
eel
Another way to do this is using the for
loop keyword and testing it against the length property of the array.
// Loop through the length of the array
for (let i = 0; i < fish.length; i++) {
console.log(fish[i]);
}
The above code will have the same output as using the forEach()
method. As an iteration method specifically intended for use with arrays, forEach()
is more concise and straightforward for this particular task.
The map()
method creates a new array with the results of a function call on each element in the array.
For an example of how to use the iteration method map()
, we can print each iteration of a loop to the console. map()
does not mutate the original array, it instead returns a new array value.
let fish = [ "piranha", "barracuda", "cod", "eel" ];
// Print out each item in the array
let printFish = fish.map(individualFish => {
console.log(individualFish);
});
printFish;
Outputpiranha
barracuda
cod
eel
We can also use map()
to change the values of each item in an array. To demonstrate this, we’ll add an s
to the end of each item in the fish
array to pluralize each word.
// Pluralize all items in the fish array
let pluralFish = fish.map(individualFish => {
return `${individualFish}s`;
});
pluralFish;
Output[ 'piranhas', 'barracudas', 'cods', 'eels' ]
The original fish
variable is unchanged, but pluralFish
now contains a modified version of the original variable.
The filter()
method creates a new array with the elements that pass the result of a given test.
We could use filter()
to return a new array containing only the items in a list that start with a specific letter. To do this, we can utilize string indexing to call the first item (or letter) in each string item of the array.
let seaCreatures = [ "shark", "whale", "squid", "starfish", "narwhal" ];
// Filter all creatures that start with "s" into a new list
let filteredList = seaCreatures.filter(creature => {
return creature[0] === "s";
});
filteredList;
Output[ 'shark', 'squid', 'starfish' ]
We tested which items in the array have an s
at the 0
index, and assigned the result into a new variable.
filter()
is an iteration method, and does not mutate the original array.
The reduce()
method will reduce an array to a single value.
This is seen commonly with numbers, such as finding the sum of all the numbers in an array.
let numbers = [ 42, 23, 16, 15, 4, 8 ];
// Get the sum of all numerical values
let sum = numbers.reduce((a, b) => {
return a + b;
});
sum;
Output108
reduce()
can also be used with strings and other data types. The value returned by reduce()
can be a number, string, array, or other data type. reduce()
is an iteration method that does not mutate the original array.
The find()
method returns the first value in an array that passes a given test.
As an example, we will create an array of sea creatures.
let seaCreatures = [ "whale", "octopus", "shark", "cuttlefish", "flounder" ];
Then we will use the find()
method to test if any of the creatures in the array are cephalopods.
// Check if a given value is a cephalopod
const isCephalopod = cephalopod => {
return [ "cuttlefish", "octopus" ].includes(cephalopod);
}
seaCreatures.find(isCephalopod);
Outputoctopus
Since octopus
was the first entry in the array to satisfy the test in the isCephalopod()
function, it is the first value to be returned.
The find()
method can help you work with arrays that contain many values.
The findIndex()
method returns the first index in an array that passes a given test.
We can use the same seaCreatures
example from the find()
method.
let seaCreatures = [ "whale", "octopus", "shark", "cuttlefish", "flounder" ];
Using the isCephalopod
test, we will find the index number instead of the value of the first match.
// Check if a given value is a cephalopod
const isCephalopod = cephalopod => {
return [ "cuttlefish", "octopus" ].includes(cephalopod);
}
seaCreatures.findIndex(isCephalopod);
Output1
octopus
is the first item to match the test and has an index of 1
, therefore it is the index number that is returned.
If the test is not satisfied, findIndex()
will return -1
.
const isThereAnEel = eel => {
return [ "eel" ].includes(eel);
}
seaCreatures.findIndex
Output-1
The findIndex()
method is particularly useful when working with arrays containing many items.
In this tutorial, we reviewed the major built-in iteration array methods in JavaScript. Iteration methods operate on every item in an array, and often perform a new function. We went over how to loop through arrays, change the value of each item in an array, filter and reduce arrays, and find values and indices.
To review the basics of arrays, read Understanding Arrays in JavaScript. For more info on syntax in Javascript, see our tutorial on “Understanding Syntax and Code Structure in JavaScript.”
Thanks for learning with the DigitalOcean Community. Check out our offerings for compute, storage, networking, and managed databases.
An array in JavaScript is a type of global object used to store data. Arrays can store multiple values in a single variable, which can condense and organize our code. JavaScript provides many built-in methods to work with arrays, including mutator, accessor, and iteration methods.
JavaScript is a high-level, object-based, dynamic scripting language popular as a tool for making webpages interactive.
This textbox defaults to using Markdown to format your answer.
You can type !ref in this text area to quickly search our full set of tutorials, documentation & marketplace offerings and insert the link!
That’s a great article. Inspired me to write a 3 part series over Arrays in JS:
https://fullstackgeek.blogspot.com/2019/01/arrays-in-javascript_27.html
https://fullstackgeek.blogspot.com/2019/01/arrays-in-javascript-part-2.html
https://fullstackgeek.blogspot.com/2019/01/filtering-sorting-arrays-javascript_31.html
Shouldn’t you make a clear distinction between js methods and js functions? Your use of the arrow function with array methods makes, this article rather confusing, for a js novice like me.