Categories: softare development

How to Remove Duplicates from a JavaScript Array

When working with arrays in JavaScript, you’ll often run into duplicate values. Removing them efficiently not only keeps your data clean but also makes your code more optimized. Let’s look at the most common ways of how to remove duplicates from a JavaScript array.

1. Using Set (ES6+)

const numbers = [1, 2, 2, 3, 4, 4, 5];
const uniqueNumbers = [...new Set(numbers)];
console.log(uniqueNumbers); // [1, 2, 3, 4, 5]

✅ Simple and efficient
✅ Best for modern JavaScript

2. Using filter() + indexOf()

const numbers = [1, 2, 2, 3, 4, 4, 5];
const uniqueNumbers = numbers.filter((value, index) => 
  numbers.indexOf(value) === index
);
console.log(uniqueNumbers); // [1, 2, 3, 4, 5]

✅ Works everywhere
⚠️ Slightly slower on large arrays

3. Using reduce() + includes()

const numbers = [1, 2, 2, 3, 4, 4, 5];
const uniqueNumbers = numbers.reduce((acc, value) => {
  if (!acc.includes(value)) acc.push(value);
  return acc;
}, []);
console.log(uniqueNumbers); // [1, 2, 3, 4, 5]

✅ Great for learning array methods

4. Using forEach() + Object Lookup

const numbers = [1, 2, 2, 3, 4, 4, 5];
const lookup = {};
const uniqueNumbers = [];

numbers.forEach(num => {
  if (!lookup[num]) {
    lookup[num] = true;
    uniqueNumbers.push(num);
  }
});

console.log(uniqueNumbers); // [1, 2, 3, 4, 5]

✅ Very fast for larger datasets

What You Should Know

The Set method is the easiest and most modern solution, but depending on the scenario (browser support, performance needs), other approaches can still be useful.

Start Learning JavaScript

Summary

How to remove duplicates from a JavaScript array is a common task with many solutions. The most modern and efficient method is using Set, while traditional methods like filter() + indexOf()reduce() + includes(), or a lookup object offer alternatives depending on performance needs and project requirements. The key takeaway: JavaScript gives you multiple tools to keep your data clean—pick the one that best fits your use case.

Recent Posts

Rate Limiting in Node JS

What is Rate Limiting? Download this article as a PDF on the Codeflare Mobile App…

2 days ago

JavaScript promise chaining

Learn on the Go. Download the Codeflare Mobile from iOS App Store.  1. What is…

5 days ago

UI/UX Design — Explained Like You’re 5

Download the Codeflare iOS app and learn on the Go 1. What UI and UX…

3 weeks ago

Costly Linux Mistakes Beginners Make

1. Running Everything as Root One of the biggest beginner errors. Many new users log…

2 months ago

How Keyloggers Work

A keylogger is a type of surveillance software or hardware that records every keystroke made…

2 months ago

JavaScript Memoization

In JavaScript, it’s commonly used for: Recursive functions (like Fibonacci) Heavy calculations Repeated API/data processing…

3 months ago