This content originally appeared on DEV Community and was authored by Randy Rivera
- Welcome back I'm sorry that it took me a while to post something. Anyways let's get back straight to it. In this post let's make a function that looks through an array of objects (first argument) and returns an array of all objects that have matching name and value pairs (second argument). Each name and value pair of the source object has to be present in the object from the collection.
- For example, if the first argument is
[{ first: "Randy", last: "Skywalker" }, { first: "Alan", last: null }, { first: "Diego", last: "Rivera" }]
, and the second argument is{ last: "Rivera" }
, then you must return the third object from the array (the first argument), because it contains the name and its value, that was passed on as the second argument.
Alright let's get to it then. Below is already pre written for you.
function names(collection, target) {
var arr = [];
// Only change code below this line
// Only change code above this line
return arr;
}
names([{ first: "Randy", last: "Skywalker" }, { first: "Alan", last: null }, { first: "Diego", last: "Rivera" }], { last: "Rivera" });
- Answer:
function names(collection, target) {
let keys = Object.keys(target);
return collection.filter(function(obj) {
for (let i = 0; i < keys.length; i++) {
if (!obj.hasOwnProperty(keys[i]) || obj[keys[i]] !== target[keys[i]]) {
return false;
}
}
return true;
})
}
names([{ first: "Randy", last: "Skywalker" }, { first: "Alan", last: null }, { first: "Diego", last: "Rivera" }], { last: "Rivera" }); // console.log would display the entire object [{ first: 'Diego', last: 'Rivera' }]
-
!obj
basically means if theobj
does not. - There's also a slightly different way of doing the for loop as well.
- Ex:
function names(collection, target) {
let keys = Object.keys(target);
return collection.filter(function(obj) {
for (let key of keys) {
if (!obj.hasOwnProperty(key) || obj[keys] !== target[keys]) {
return false;
}
}
return true;
})
}
This content originally appeared on DEV Community and was authored by Randy Rivera
Print
Share
Comment
Cite
Upload
Translate
Updates
There are no updates yet.
Click the Upload button above to add an update.
data:image/s3,"s3://crabby-images/02712/02712ed05be9b9b1bd4a40eaf998d4769e8409c0" alt=""
APA
MLA
Randy Rivera | Sciencx (2021-07-22T23:27:53+00:00) Matching Properties and Values in the Object.. Retrieved from https://www.scien.cx/2021/07/22/matching-properties-and-values-in-the-object/
" » Matching Properties and Values in the Object.." Randy Rivera | Sciencx - Thursday July 22, 2021, https://www.scien.cx/2021/07/22/matching-properties-and-values-in-the-object/
HARVARDRandy Rivera | Sciencx Thursday July 22, 2021 » Matching Properties and Values in the Object.., viewed ,<https://www.scien.cx/2021/07/22/matching-properties-and-values-in-the-object/>
VANCOUVERRandy Rivera | Sciencx - » Matching Properties and Values in the Object.. [Internet]. [Accessed ]. Available from: https://www.scien.cx/2021/07/22/matching-properties-and-values-in-the-object/
CHICAGO" » Matching Properties and Values in the Object.." Randy Rivera | Sciencx - Accessed . https://www.scien.cx/2021/07/22/matching-properties-and-values-in-the-object/
IEEE" » Matching Properties and Values in the Object.." Randy Rivera | Sciencx [Online]. Available: https://www.scien.cx/2021/07/22/matching-properties-and-values-in-the-object/. [Accessed: ]
rf:citation » Matching Properties and Values in the Object. | Randy Rivera | Sciencx | https://www.scien.cx/2021/07/22/matching-properties-and-values-in-the-object/ |
Please log in to upload a file.
There are no updates yet.
Click the Upload button above to add an update.