How to Separate Array of Objects into Multiple Objects in JavaScript ?
Last Updated :
19 Jul, 2024
In JavaScript, the task of separating an array of objects into multiple objects involves organizing and restructuring data based on specific criteria or properties. This process is often necessary when dealing with datasets that need to be grouped or segmented for easier analysis or manipulation.
There are various methods to achieve this separation which are as follows
Using Array.prototype.reduce
The reduce method is used to separate an array of objects into multiple objects based on a specified property. This method initializes an empty object as an accumulator and iterates through the array, grouping objects by the specified property. It checks whether a property value exists in the accumulator, creating a new array for that value if it doesn't, and then appends the current object to that array.
Example: In this, the reduce function iterates over the array and groups fruits based on the category.
JavaScript
// Array of objects
const array = [
{ id: 1, category: "A", value: "apple" },
{ id: 2, category: "B", value: "banana" },
{ id: 3, category: "A", value: "avocado" },
];
const groupedObjects = array.reduce((result, obj) => {
(result[obj.category] = result[obj.category] || []).push(obj);
return result;
}, {});
// Output
console.log(groupedObjects);
Output{
A: [
{ id: 1, category: 'A', value: 'apple' },
{ id: 3, category: 'A', value: 'avocado' }
],
B: [ { id: 2, category: 'B', value: 'banana' } ]
}
Using Array.prototype.forEach
The forEach method is utilised to achieve object separation by iterating over the array of objects. It maintains an empty object to store the grouped objects, and for each object in the array, it checks whether an array for the specific property exists in the accumulator. If not, a new array is created, and the object is appended to it.
Example: In this, the for-each categories for-each categories loop is used to iterate over the array and group fruits based on the category.
JavaScript
// Array of objects
const array = [
{ id: 1, category: "A", value: "apple" },
{ id: 2, category: "B", value: "banana" },
{ id: 3, category: "A", value: "avocado" },
// ... more objects here
];
const groupedObjects = {};
array.forEach((obj) => {
groupedObjects[obj.category] =
groupedObjects[obj.category] || [];
groupedObjects[obj.category].push(obj);
});
console.log(groupedObjects);
Output{
A: [
{ id: 1, category: 'A', value: 'apple' },
{ id: 3, category: 'A', value: 'avocado' }
],
B: [ { id: 2, category: 'B', value: 'banana' } ]
}
Using Map data structure
The map data structure is used to create a mapping between property values and arrays of objects. The array is traversed using a forEach loop, and for each object, the Map is updated to include the object in the corresponding array. The final result is a Map where keys are property values, and values are arrays of objects.
Finally, the Map is converted back to an object for easier use.
Example: In this, the Map data structure is used to create a mapping between categories and arrays of objects to group fruits based on the category.
JavaScript
// Array of objects
const array = [
{ id: 1, category: "A", value: "apple" },
{ id: 2, category: "B", value: "banana" },
{ id: 3, category: "A", value: "avocado" },
];
// Newly create map datastructure
const groupedObjects = new Map();
array.forEach((obj) => {
const category = obj.category;
groupedObjects.set(
category,
(groupedObjects.get(category) || []).concat(obj)
);
});
console.log(Object.fromEntries(groupedObjects));
Output{
A: [
{ id: 1, category: 'A', value: 'apple' },
{ id: 3, category: 'A', value: 'avocado' }
],
B: [ { id: 2, category: 'B', value: 'banana' } ]
}
Using Lodash _.groupBy
The Lodash library offers a convenient and efficient way to group an array of objects based on a specified property using the _.groupBy method. This method takes the array and a function that returns the key to group by, creating an object where the keys are the group names and the values are arrays of objects belonging to those groups.
Example: In this example, the Lodash _.groupBy method is used to group fruits based on the category.
JavaScript
const _ = require('lodash');
// Array of objects
const array = [
{ id: 1, category: "A", value: "apple" },
{ id: 2, category: "B", value: "banana" },
{ id: 3, category: "A", value: "avocado" },
];
// Using Lodash _.groupBy
const groupedObjects = _.groupBy(array, 'category');
console.log(groupedObjects);
Output:
{
A: [
{ id: 1, category: 'A', value: 'apple' },
{ id: 3, category: 'A', value: 'avocado' }
],
B: [ { id: 2, category: 'B', value: 'banana' } ]
}
Using Array.prototype.sort with a Custom Grouping Function
This method involves first sorting the array by the specified property and then iterating through the sorted array to group the objects into a new object.
Example: To demonstrate grouping fruits based on the category using sort and a custom grouping function.
JavaScript
// Array of objects
const array = [
{ id: 1, category: "A", value: "Nikunj" },
{ id: 2, category: "B", value: "Yash" },
{ id: 3, category: "A", value: "Dhruv" },
{ id: 4, category: "B", value: "Arati" },
];
// Custom function to group by a specified property
function groupBy(array, property) {
// Sort the array by the specified property
array.sort((a, b) => (a[property] > b[property] ? 1 : -1));
// Initialize the result object and current group
const result = {};
let currentGroup = [];
let currentValue = array[0][property];
// Iterate through the sorted array to group objects
array.forEach((item) => {
if (item[property] !== currentValue) {
result[currentValue] = currentGroup;
currentGroup = [];
currentValue = item[property];
}
currentGroup.push(item);
});
// Add the last group to the result
result[currentValue] = currentGroup;
return result;
}
// Using the custom grouping function
const groupedObjects = groupBy(array, 'category');
console.log(groupedObjects);
Output{
A: [
{ id: 3, category: 'A', value: 'Dhruv' },
{ id: 1, category: 'A', value: 'Nikunj' }
],
B: [
{ id: 4, category: 'B', value: 'Arati' },
{ id: 2, category: 'B', value: 'Yash'...
Similar Reads
How to Remove Multiple Objects from Nested Array of Objects in JavaScript ?
A nested array of objects is an array of arrays that contain multiple objects as their elements. Removing multiple objects from the nested array of objects in JavaSript can be accomplished in different ways as listed below:Table of ContentUsing filter() with some() methodUsing filter() with includes
7 min read
How to Convert an Object into Array of Objects in JavaScript?
Here are the different methods to convert an object into an array of objects in JavaScript1. Using Object.values() methodObject.values() method extracts the property values of an object and returns them as an array, converting the original object into an array of objects.JavaScriptconst a = { java:
3 min read
How to Merge Multiple Array of Object by ID in JavaScript?
Merging multiple arrays of objects by a shared key, like ID, in JavaScript, is used when consolidating data from various sources, such as API responses or databases. This process involves combining objects that have the same key into a single object, allowing developers to manage and manipulate comp
4 min read
How to Convert Array of Objects into Unique Array of Objects in JavaScript ?
Arrays of objects are a common data structure in JavaScript, often used to store and manipulate collections of related data. However, there are scenarios where you may need to convert an array of objects into a unique array, removing any duplicate objects based on specific criteria. JavaScript has v
8 min read
How to Filter an Array of Objects Based on Multiple Properties in JavaScript ?
Filtering an array of objects based on multiple properties is a common task in JavaScript. It allows us to selectively extract items from an array that satisfy specific conditions. We will explore different approaches to achieve this task.These are the following approaches:Table of ContentUsing the
6 min read
How to Push an Array into Object in JavaScript?
To push an array into the Object in JavaScript, we will be using the JavaScript Array push() method. First, ensure that the object contains a property to hold the array data. Then use the push function to add the new array in the object.Understanding the push() MethodThe array push() method adds one
2 min read
How to convert a map to array of objects in JavaScript?
A map in JavaScript is a set of unique key and value pairs that can hold multiple values with only a single occurrence. Sometimes, you may be required to convert a map into an array of objects that contains the key-value pairs of the map as the values of the object keys. Let us discuss some methods
6 min read
How to remove object from array of objects using JavaScript ?
Removing an object from an array of objects in JavaScript refers to the process of eliminating a specific object from the array based on certain conditions, like matching a property value. This task is common in data manipulation, ensuring the array only contains the desired elements.There are two a
2 min read
How to Store an Object Inside an Array in JavaScript ?
Storing an object inside an array in JavScript involves placing the object as an element within the array. The array becomes a collection of objects, allowing for convenient organization and manipulation of multiple data structures in a single container. Following are the approaches through which it
3 min read
How to Convert Array into Array of Objects using map() & reduce() in JavaScript?
An array of objects can contain multiple objects with the same properties i.e. key-value pairs. But a map does not contain duplicate values which means if you convert an array of objects with duplicate objects into a map, it will contain only the unique key-value pairs. Below are the approaches to c
2 min read