Home >Web Front-end >JS Tutorial >JavaScript Array Methods: `forEach`, `map`, `filter`, and `reduce`
JavaScript provides several powerful methods to work with arrays. These methods—forEach, map, filter, and reduce—can make your code more efficient and easier to read. Let's explore these methods using simple analogies and examples.
Analogy: Playing with each toy in the box
Imagine you have a box of toys, and you want to play with each toy one by one. You take each toy out of the box, play with it, and then put it back.
Example:
let toys = ['car', 'doll', 'ball']; toys.forEach(toy => { console.log('Playing with', toy); });
Explanation:
You look at each toy in the box and play with it.
Analogy: Changing each toy into something new
Suppose you have a box of toys and you want to turn each toy into something else. For example, you turn each car into a race car, each doll into a superhero, and each ball into a basketball.
Example:
let toys = ['car', 'doll', 'ball']; let newToys = toys.map(toy => { return toy + ' (new version)'; }); console.log(newToys);
Explanation:
You transform each toy into a new version and put the new toys into a new box.
Analogy: Choosing only certain toys to play with
You have a box of toys, but today you only want to play with the toys that are red. So, you look through the box and take out only the red toys.
Example:
let toys = ['red car', 'blue doll', 'red ball']; let redToys = toys.filter(toy => toy.includes('red')); console.log(redToys);
Explanation:
You select only the toys that match a certain condition (in this case, being red).
Analogy: Combining all toys into one mega toy
Imagine you want to create one big toy by combining all the toys together. You take each toy and add it to the mega toy one by one.
Example:
let toys = ['car', 'doll', 'ball']; let megaToy = toys.reduce((combinedToys, toy) => { return combinedToys + ' ' + toy; }, ''); console.log(megaToy);
Explanation:
You start with an empty mega toy and keep adding each toy to it until you have one big toy.
Let's say you have a box of different toys, and you want to:
let toys = ['blue car', 'red doll', 'blue ball']; toys.forEach(toy => { console.log('Toy:', toy); }); let newToys = toys.map(toy => { return toy + ' (new version)'; }); let blueToys = newToys.filter(toy => toy.includes('blue')); let megaToy = blueToys.reduce((combinedToys, toy) => { return combinedToys + ' ' + toy; }, ''); console.log(megaToy);
Explanation:
toys.forEach(function(toy) { console.log(this.prefix + toy); }, { prefix: 'Toy: ' });
let newToys = toys.map(function(toy) { return this.prefix + toy; }, { prefix: 'New: ' });
let toyLengths = toys.map(toy => toy.length);
let complexFilter = toys.filter(toy => toy.includes('blue') && toy.length > 4);
let sum = [1, 2, 3].reduce((total, num) => total + num, 0);
let toyCounts = toys.reduce((counts, toy) => { counts[toy] = (counts[toy] || 0) + 1; return counts; }, {});
By understanding these methods and their advanced options, you can write more efficient and readable JavaScript code. Happy coding!
The above is the detailed content of JavaScript Array Methods: `forEach`, `map`, `filter`, and `reduce`. For more information, please follow other related articles on the PHP Chinese website!