Introduction
Are you currently learning the JavaScript language and are within the subject area of loops, iteration, and arrays? Plus you stumbled upon these two methods: Array.forEach() and Array.map(). Finally, are you confused? No worries, because in this post, we are going to answer the differences between these two methods.
What is the Array.forEach?
The forEach method allows you to run a function/method for every element inside the array.
The syntax,
-
- [].forEach(function(item, index, array){
-
- });
Quick Example
- ["apple", "mango", "avocado", "dragon fruit"].forEach(console.log);
Output
As you can see, we have shown the 3 arguments of the forEach method by passing the console.log method. Easy isn’t it? I will get in-depth in the later section.
What is the Array.map?
The map method returns a new set of arrays but doesn’t change the original array.
The syntax,
-
- [].map(function(currentValue, index,currentArray){
-
- }, thisValue)
Quick Example
- ["apple", "mango", "avocado", "dragon fruit"].map((currentValue) => currentValue.toUpperCase());
Output
As you can see, we have shown how the map method returns a new set of arrays in uppercase.
The difference between forEach and map
Now, that we have seen the syntax of these two array methods, we can go and answer their differences. Will do our best to explain the difference with the use of code samples. However, before going into each detail, we need some form of data.
- const employees =
- [{
- employee: 'Eleanor R. Crane',
- company: 'Tellus Faucibus Leo Incorporated',
- dailyRate: 0,
- salary: 15200
- },
- {
- employee: 'Haviva E. Lane',
- company: 'Eu Neque Pellentesque Incorporated',
- dailyRate: 0,
- salary: 13333
- },
- {
- employee: 'Merrill F. Morrison',
- company: 'Lobortis Quam Ltd',
- dailyRate: 0,
- salary: 1450
- },
- {
- employee: 'Halee L. Hensley',
- company: 'Elit Corp.',
- dailyRate: 0,
- salary: 15872
- },
- {
- employee: 'Hamish T. Trevino',
- company: 'Rhoncus LLC',
- dailyRate: 0,
- salary: 14214
- }];
forEach
- Has no result value or doesn’t return anything.
- Iterates over a list and applies some operation with side effects to each list. If you need to do something meaningful, you can do some side effects while iterating.
- const TOTAL_WORKING_DAYS = 261;
-
-
- const dailyRate = (item, index, array) => array[index].dailyRate = Math.floor(((item.salary * 12) / (TOTAL_WORKING_DAYS)));
-
-
- let dailyRateEmployeeResults = employees.forEach(dailyRate);
-
- console.log(dailyRateEmployeeResults);
-
- console.log(employees);
Output
Thoughts on the forEach method
Every time working with the forEach method, I have observed that it describes the control flow. No mystery, right?. Hence, we can say that it is imperative.
map
- Returns a new list without changing anything else.
- Has no side effects, it doesn't change the original array-list.
- const TOTAL_WORKING_DAYS = 261;
-
- const getDailyRate = salary => Math.floor(((salary * 12) / (TOTAL_WORKING_DAYS)));
-
- const dailyRate = employee => Object.assign({}, { employee: employee.employee, dailyRate: getDailyRate(employee.salary) });
-
-
- const newEmployees = employees.map(dailyRate);
-
-
- console.log(newEmployees);
-
-
- console.log(employees);
Output
Thoughts on the map method
Again, going back to my observations but with the map method. I have observed that it is somewhat of a flow of data. Meaning, when you have an input array then it outputs a new array through the use of this method. Hence, we can say that it is functional.
Conclusion
It is obvious that these two methods have opposing views when it comes to usage which has its own pros and cons. Therefore, we can conclude that the forEach method is using the imperative paradigm while the map method uses the functional programming paradigm.
Summary
We have seen the difference between forEach and map. We started from its syntax all the way up to the differences with code samples. I hope you have enjoyed this article, as much as I have enjoyed writing it. Stay tuned for more. This post was originally posted
here. Many thanks, and until next time, happy programming!