How to Use the filter() Method for Arrays in JavaScript
Traducciones al EspañolEstamos traduciendo nuestros guías y tutoriales al Español. Es posible que usted esté viendo una traducción generada automáticamente. Estamos trabajando con traductores profesionales para verificar las traducciones de nuestro sitio web. Este proyecto es un trabajo en curso.
JavaScript’s arrays include a filter
method, designed to conveniently create new arrays out of existing ones. So how does it work, and how can you start using it on your arrays? This guide explains JavaScript’s filter
method and how to use it to filter arrays containing numbers, strings, and even objects.
What Is the JavaScript filter Method?
In JavaScript, arrays each come with a filter
method, which can be used to generate a new array from the original given a set of criteria. The method accomplishes this by taking a function as an argument and applying that function to each item in the original array. Each item for which the function returns true
gets added to a new array, which the filter
method returns at the end.
To break that down, here is an example. Follow along with the comments in the example to see how each part works:
- File: filter_method_example.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
// Start with an array. const exampleArray = [1, 2, 3, 4, 5, 6]; // Create a new array by using a filter on the original array. let newExampleArray = exampleArray.filter(function(item) { // Filter takes an anonymous function as an argument, and that function // gets an argument passed into it, named `item` here. That argument // contains an element from the array. // Logic gets tested for each item in the array. In this case, whether // the item divides by 2 without a remainder. return item % 2 === 0; }); // The above results in a new array, `newExampleArray`, with these contents: // [2, 4, 6]
How to Use the filter Method
Above, you can see an example of the filter method in action. The sections that follow elaborate on this, showing you examples of three different kinds of arrays.
These are not the only kinds of arrays that the filter
method works on, however. Any kind of array works. The kinds of arrays selected and shown here are meant to illustrate the filter
method’s capabilities on some of the most common array contents. That way, you have the understanding you need to be able to apply the method for any kind of array you might encounter.
Using the filter Method for Arrays of Numbers
The best place to start is the simplest of the arrays: arrays containing only numbers. The filter
method lets you create a new number array from an existing array based on the criteria you provide. Part of what makes a number array easier to start with is that the criteria typically use frequently-used and widely-known operators.
For instance, you can create a new array of all numbers below 20 in an existing array by filtering for < 20
. This is exactly what is done for the smallNumberArray
in the example below. The example then does the opposite for the largeNumberArray
, filtering for numbers equal to or greater than 20, using >= 20
.
You can branch out from there to more advanced operations. The last filter
in the example below uses the remainder operator — %
— to get an array of numbers that are multiples of nine.
- File: filter_array_of_numbers.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
const numberArray = [9, 45, 27, 18, 36, 19]; let smallerNumberArray = numberArray.filter((item) => { return item > 20; }); // [45, 27, 36] let largerNumberArray = numberArray.filter((item) => { return item <= 20; }); // [9, 18, 19] let multipleOfNineArray = numberArray.filter((item) => { return item % 9 === 0; }); // [9, 45, 27, 18, 36]
Using the filter Method for Arrays of Strings
The same approach can be used for arrays containing strings. The only more complicated thing with these arrays is that the filtering uses string operations, which might not be as familiar.
Strings can be compared using the equality (==
) or string equality (===
) operators.
But you can also get a string’s length using its length
property, which you can then filter on like you would a number. You can check whether a string includes a given sub-string using the includes
method. Both of these options are applied in the examples below.
And there are many more options, like the ability to pick a specific character (using exampleString[0]
to get the first character).
Unless you want your strings to be case-sensitive, you should convert them to lowercase before evaluating them for sub-strings and the like. This is done in the arrStringArray
example below, allowing the string Array
to match for including arr
.
- File: filter_array_of_strings.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16
const stringArray = ["An", "Array", "Of", "Strings"]; let longerStringArray = stringArray.filter((item) => { return item.length > 2; }); // ["array", "strings"] let shorterStringArray = stringArray.filter((item) => { return item.length <= 2; }); // ["an", "of"] let arrStringArray = stringArray.filter((item) => { return item.toLowerCase().includes("arr"); }); // ["array"]
Using the filter Method for Arrays of Objects
Objects, though potentially much more complicated, actually do not present much more of a challenge for filtering in an array. Generally, you just want to access one or more properties in common across the array’s objects. From there, the filtering works just as it would with number and string arrays.
You can see this in the first two examples below. The first, consoleObjectArray
, checks for items with a type
property that matches the string console
. The second, longerNameObjectArray
, checks for items with names longer than five characters.
The last example does a number comparison, but also adds a little more logic. It first checks the type
attribute to make sure the item is a console
, returning false
if it is not. Only then, for the console
items, does it filter by number. This is a good way to take advantage of objects’ properties to apply multiple filters at the same time.
As a side note, you can do something similar on number and string arrays. For instance, on a string array, you can check for length and sub-string using a similar approach.
- File: filter_array_of_objects.js
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
const objectArray = [ {type: "console", name: "Playstation", year: 2020}, {type: "console", name: "Switch", year: 2017}, {type: "console", name: "Xbox", year: 2019}, {type: "company", name: "Microsoft"}, {type: "company", name: "Nintendo"}, {type: "company", name: "Sony"} ]; let consoleObjectArray = objectArray.filter((item) => { return item.type.toLowerCase() === "console"; }); // [{type: "console", name: "Playstation"}, {type: "console", name: "Switch"}, {type: "console", name: "Xbox"}] let longerNameObjectArray = objectArray.filter((item) => { return item.name.length > 5; }); // [{type: "console", name: "Playstation"}, {type: "company", name: "Microsoft"}, {type: "company", name: "Nintendo"}] let newerConsolesArray = objectArray.fitler((item) => { if (item.type === "console") { return item.year > 2017; } else { return false; } }); // [{type: "console", name: "Playstation", year: 2020}, {type: "console", name: "Xbox", year: 2019}]
Conclusion
With that, you have the basics you need for starting to use the array filter
method in your JavaScript code. The above does not cover everything you can do with this versatile method. But it does show the possibilities and gives you a template you can use to explore and adapt.
Have more questions or want some help getting started? Feel free to reach out to our Support team.
More Information
You may wish to consult the following resources for additional information on this topic. While these are provided in the hope that they will be useful, please note that we cannot vouch for the accuracy or timeliness of externally hosted materials.
This page was originally published on