DEV Community

Cover image for Building Your Own Map, Filter, and Reduce in JavaScript
Kafeel Ahmad (kaf shekh)
Kafeel Ahmad (kaf shekh)

Posted on

Building Your Own Map, Filter, and Reduce in JavaScript

In this post, we delve deep into the inner workings of these JavaScript powerhouses. We won't just use them; we'll deconstruct and reconstruct them, crafting our own custom map, filter, and reduce methods using Array.prototype. By dissecting these functions, you'll gain invaluable insights into their operations, equipping you to leverage JavaScript's array manipulation capabilities adeptly.

Custom Map method:

The map method in JavaScript is instrumental for transforming arrays by applying a function to each element. Let's create a custom map method using Array.prototype:

// Custom map method for arrays
Array.prototype.customMap = function(callback) {
  const result = [];

  for (let i = 0; i < this.length; i++) {
    result.push(callback(this[i], i, this));
  }

  return result;
};

// Example usage:
const numbers = [1, 2, 3, 4, 5];
const doubledNumbers = numbers.customMap((num) => num * 2);
console.log(doubledNumbers); // [2, 4, 6, 8, 10]
Enter fullscreen mode Exit fullscreen mode

In this custom map method, we iterate over each element of the input array, apply the provided callback function to each element, and push the result into a new array, which is then returned.

Custom filter Method:

The filter method enables the creation of a new array containing elements that satisfy a specific condition. Let's create a custom filter method using Array.prototype:

// Custom filter method for arrays
Array.prototype.customFilter = function(callback) {
  const result = [];

  for (let i = 0; i < this.length; i++) {
    if (callback(this[i], i, this)) {
      result.push(this[i]);
    }
  }

  return result;
};

// Example usage:
const numbers = [1, 2, 3, 4, 5];
const evenNumbers = numbers.customFilter((num) => num % 2 === 0);
console.log(evenNumbers); // [2, 4]
Enter fullscreen mode Exit fullscreen mode

In this custom filter method, we iterate over each element of the input array, apply the provided callback function to each element, and if the callback returns true, we add the element to the result array, which is then returned.

Custom reduce Method:

Creating a custom reduce method involves handling an initial value. Let's create a custom reduce method using Array.prototype:

// Custom reduce method for arrays
Array.prototype.customReduce = function(callback, initialValue) {
  let accumulator = initialValue === undefined ? this[0] : initialValue;
  const startIndex = initialValue === undefined ? 1 : 0;

  for (let i = startIndex; i < this.length; i++) {
    accumulator = callback(accumulator, this[i], i, this);
  }

  return accumulator;
};

// Example usage:
const numbers = [1, 2, 3, 4, 5];
const sum = numbers.customReduce((accumulator, current) => accumulator + current, 0);
console.log(sum); // 15
Enter fullscreen mode Exit fullscreen mode

Now, we have a customReduce method that can be used on any array. In this custom reduce method, we iterate over the array, starting from either the provided initialValue or the first element if no initial value is provided. We apply the callback function to each element, updating the accumulator value at each step, and finally return the accumulated result.

Conclusion:

Understanding the inner workings of JavaScript’s array methods such as map, filter, and reduce is essential for proficient JavaScript development. By creating custom versions of these methods using Array.prototype, we've gained insights into their underlying principles. These custom methods not only aid in conceptual understanding but also underscore the versatility and power of JavaScript as a programming language.

Sentry blog image

How I fixed 20 seconds of lag for every user in just 20 minutes.

Our AI agent was running 10-20 seconds slower than it should, impacting both our own developers and our early adopters. See how I used Sentry Profiling to fix it in record time.

Read more

Top comments (4)

Collapse
 
jonrandy profile image
Jon Randy πŸŽ–οΈ β€’

Are these custom versions intended to duplicate the functionality of the originals? If so, both filter and map are incorrect.

Collapse
 
kafeel_ahmad profile image
Kafeel Ahmad (kaf shekh) β€’

absolutely not, it is just for creating custom function just like inbuilt functions in
JavaScript.

Collapse
 
jonrandy profile image
Jon Randy πŸŽ–οΈ β€’ β€’ Edited

Therein lies the issue - the filter and map implementations shown are not just like the built-in ones. They are both missing the optional second parameter thisArg.

Thread Thread
 
kafeel_ahmad profile image
Kafeel Ahmad (kaf shekh) β€’

It's just example to create a custom function in JavaScript.

A Workflow Copilot. Tailored to You.

Pieces.app image

Our desktop app, with its intelligent copilot, streamlines coding by generating snippets, extracting code from screenshots, and accelerating problem-solving.

Read the docs

πŸ‘‹ Kindness is contagious

Discover a treasure trove of wisdom within this insightful piece, highly respected in the nurturing DEV Community enviroment. Developers, whether novice or expert, are encouraged to participate and add to our shared knowledge basin.

A simple "thank you" can illuminate someone's day. Express your appreciation in the comments section!

On DEV, sharing ideas smoothens our journey and strengthens our community ties. Learn something useful? Offering a quick thanks to the author is deeply appreciated.

Okay