2018-09-30 23:01:58 +01:00
---
id: 587d7b7d367417b2b2512b1e
title: Generate an Array of All Object Keys with Object.keys()
challengeType: 1
2019-08-05 09:17:33 -07:00
forumTopicId: 301160
2018-09-30 23:01:58 +01:00
---
## Description
< section id = 'description' >
We can also generate an array which contains all the keys stored in an object using the < code > Object.keys()< / code > method and passing in an object as the argument. This will return an array with strings representing each property in the object. Again, there will be no specific order to the entries in the array.
< / section >
## Instructions
< section id = 'instructions' >
Finish writing the < code > getArrayOfUsers< / code > function so that it returns an array containing all the properties in the object it receives as an argument.
< / section >
## Tests
< section id = 'tests' >
```yml
2018-10-04 14:37:37 +01:00
tests:
2018-10-20 21:02:47 +03:00
- text: The < code > users</ code > object only contains the keys < code > Alan</ code > , < code > Jeff</ code > , < code > Sarah</ code > , and < code > Ryan</ code >
2019-07-24 01:56:38 -07:00
testString: assert('Alan' in users & & 'Jeff' in users & & 'Sarah' in users & & 'Ryan' in users & & Object.keys(users).length === 4);
2018-10-04 14:37:37 +01:00
- text: The < code > getArrayOfUsers</ code > function returns an array which contains all the keys in the < code > users</ code > object
2019-07-24 01:56:38 -07:00
testString: assert((function() { users.Sam = {}; users.Lewis = {}; let R = getArrayOfUsers(users); return (R.indexOf('Alan') !== -1 & & R.indexOf('Jeff') !== -1 & & R.indexOf('Sarah') !== -1 & & R.indexOf('Ryan') !== -1 & & R.indexOf('Sam') !== -1 & & R.indexOf('Lewis') !== -1); })() === true);
2018-09-30 23:01:58 +01:00
```
< / section >
## Challenge Seed
< section id = 'challengeSeed' >
< div id = 'js-seed' >
```js
let users = {
Alan: {
age: 27,
online: false
},
Jeff: {
age: 32,
online: true
},
Sarah: {
age: 48,
online: false
},
Ryan: {
age: 19,
online: true
}
};
function getArrayOfUsers(obj) {
// change code below this line
// change code above this line
}
console.log(getArrayOfUsers(users));
```
< / div >
< / section >
## Solution
< section id = 'solution' >
```js
2018-10-20 21:02:47 +03:00
let users = {
Alan: {
age: 27,
online: false
},
Jeff: {
age: 32,
online: true
},
Sarah: {
age: 48,
online: false
},
Ryan: {
age: 19,
online: true
}
};
2018-10-15 17:19:27 -05:00
function getArrayOfUsers(obj) {
return Object.keys(users);
}
2018-10-20 21:02:47 +03:00
console.log(getArrayOfUsers(users));
2018-09-30 23:01:58 +01:00
```
2019-07-18 08:24:12 -07:00
2018-09-30 23:01:58 +01:00
< / section >