Tell us what’s happening:
I already found the solution to this problem, but I was wondering if someone could clarify why the selector I used below does not work:
My selector (causes error “Cannot read property ‘online’ of undefined”):
if (obj.user.online == true) {
count++;
}
Solution (correct selector):
if (obj[user].online == true) {
count++;
}
Can someone please explain why you need to use bracket notation (obj[user].online) instead of dot notation (obj.user.online)?
Your code so far
let users = {
Alan: {
age: 27,
online: false
},
Jeff: {
age: 32,
online: true
},
Sarah: {
age: 48,
online: false
},
Ryan: {
age: 19,
online: true
}
};
function countOnline(obj) {
// change code below this line
let count = 0;
for (let user in obj) {
if (obj.user.online == true) {
count++;
}
}
return count;
// change code above this line
}
console.log(countOnline(users));
Your browser information:
User Agent is: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/70.0.3538.110 Safari/537.36
.
Link to the challenge:
https://learn.freecodecamp.org/javascript-algorithms-and-data-structures/basic-data-structures/-iterate-through-the-keys-of-an-object-with-a-for---in-statement