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 Content
Using filter() with some() method
This approach uses the filter() method with the some() method to remove objects from each inner array based on the condition that their id should not match any id in the objtoRemove array.
Syntax:
let newArray = originalArray.filter((element) => {
return !conditionArray.some((conditionElement) => condition);
});
Example: The below code uses the filter() with some() method to remove multiple objects from a nested array of objects in JavaScript.
let arr = [ [
{ id: 1, name: "Geek1" },
{ id: 2, name: "Geek2" },
],
[
{ id: 3, name: "Geek3" },
{ id: 4, name: "Geek4" },
],
]; let objtoRemove = [ { id: 2, name: "Geek2" },
{ id: 4, name: "Geek4" }
]; // removing objects using some function let outputArr = arr.map((inArr) => inArr.filter((geek) =>
!objtoRemove.some((obj) =>
obj.id === geek.id))
); console.log( "Before:" , arr);
console.log( "After:" , outputArr);
|
Before: [ [ { id: 1, name: 'Geek1' }, { id: 2, name: 'Geek2' } ], [ { id: 3, name: 'Geek3' }, { id: 4, name: 'Geek4' } ] ] After: [ [ { id: 1, name: 'Geek1' } ], [ { id: 3, name: 'Geek3' } ] ]
Using filter() with includes() method
This approach uses the filter() with includes() method to remove objects whose id matches an id in the objtoRemove array.
Syntax:
let newArray = originalArray.filter((element) => {
return !conditionArray.map((conditionElement) => conditionElement.id).includes(element.id);
});
Example: The below code uses the filter() with includes() method to remove multiple objects from a nested array of objects in JavaScript.
let arr = [ [
{ id: 1, name: "Geek1" },
{ id: 2, name: "Geek2" },
],
[
{ id: 3, name: "Geek3" },
{ id: 4, name: "Geek4" },
],
]; let objtoRemove = [ { id: 2, name: "Geek2" },
{ id: 4, name: "Geek4" }
]; // removing objects using some function let outputArr = arr.map((inArr) => inArr.filter((geek) =>
!objtoRemove.map((obj) =>
obj.id).includes(geek.id))
); console.log( "Before:" , arr);
console.log( "After:" , outputArr);
|
Before: [ [ { id: 1, name: 'Geek1' }, { id: 2, name: 'Geek2' } ], [ { id: 3, name: 'Geek3' }, { id: 4, name: 'Geek4' } ] ] After: [ [ { id: 1, name: 'Geek1' } ], [ { id: 3, name: 'Geek3' } ] ]
Using filter( ) with findIndex() method
This approach uses the filter() with the findIndex() method to remove objects from the inner array where the id matches any id in the objToRemove array using the findIndex() method.
Syntax:
let newArray = originalArray.map((elementArray) =>
elementArray.filter((element) =>
objArray.findIndex((obj) => obj.id === element.id) === -1
)
);
Example: The below code uses the filter() with findIndex() method to remove multiple objects from a nested array of objects in JavaScript.
let arr = [ [
{ id: 1, name: "Geek1" },
{ id: 2, name: "Geek2" },
],
[
{ id: 3, name: "Geek3" },
{ id: 4, name: "Geek4" },
],
]; let objtoRemove = [ { id: 2, name: "Geek2" },
{ id: 4, name: "Geek4" }
]; // removing objects using some function let outputArr = arr.map((inArr) => inArr.filter((geek) =>
objtoRemove.findIndex((obj) =>
obj.id === geek.id) === -1)
); console.log( "Before:" , arr);
console.log( "After:" , outputArr);
|
Before: [ [ { id: 1, name: 'Geek1' }, { id: 2, name: 'Geek2' } ], [ { id: 3, name: 'Geek3' }, { id: 4, name: 'Geek4' } ] ] After: [ [ { id: 1, name: 'Geek1' } ], [ { id: 3, name: 'Geek3' } ] ]
Using filter() with reduce() method
This approach uses the filter() with reduce() method to remove objects from each inner array where the id matches an id in the objToRemove array.
Syntax:
let newArray = originalArray.map((elementArray) =>
elementArray.reduce((accumulator, element) => {
// condition
if (/* condition */) {
accumulator.push(element);
}
return accumulator;
}, [])
);
Example: The below code uses the filter() with reduce() method to remove multiple objects from a nested array of objects in JavaScript.
let arr = [ [
{ id: 1, name: "Geek1" },
{ id: 2, name: "Geek2" },
],
[
{ id: 3, name: "Geek3" },
{ id: 4, name: "Geek4" },
],
]; let objtoRemove = [ { id: 2, name: "Geek2" },
{ id: 4, name: "Geek4" }
]; // removing objects using some function let outputArr = arr.map((inArr) => inArr.reduce((acc, geek) => {
if (!objtoRemove.some((obj) =>
obj.id === geek.id))
{
acc.push(geek);
}
return acc;
}, [])
); console.log( "Before:" , arr);
console.log( "After:" , outputArr);
|
Before: [ [ { id: 1, name: 'Geek1' }, { id: 2, name: 'Geek2' } ], [ { id: 3, name: 'Geek3' }, { id: 4, name: 'Geek4' } ] ] After: [ [ { id: 1, name: 'Geek1' } ], [ { id: 3, name: 'Geek3' } ] ]