mirror of
https://github.com/freeCodeCamp/freeCodeCamp.git
synced 2026-04-10 22:00:43 -04:00
chore(i18n,learn): processed translations (#50292)
This commit is contained in:
@@ -8,23 +8,28 @@ dashedName: iterate-through-the-keys-of-an-object-with-a-for---in-statement
|
||||
|
||||
# --description--
|
||||
|
||||
A veces es necesario iterar por todas las claves de un objeto. Esto requiere una sintaxis específica en JavaScript llamada sentencia <dfn>for...in</dfn>. Para nuestro objeto `users`, esto podría verse así:
|
||||
Sometimes you need to iterate through all the keys within an object. You can use a <dfn>for...in</dfn> loop to do this. The for...in loop looks like:
|
||||
|
||||
```js
|
||||
for (let user in users) {
|
||||
console.log(user);
|
||||
```javascript
|
||||
const refrigerator = {
|
||||
'milk': 1,
|
||||
'eggs': 12,
|
||||
};
|
||||
|
||||
for (const food in refrigerator) {
|
||||
console.log(food, refrigerator[food]);
|
||||
}
|
||||
```
|
||||
|
||||
Esto devolvería `Alan`, `Jeff`, y `Sarah` - cada valor en su propia línea.
|
||||
This code logs `milk 1` and `eggs 12`, with each key-value pair on its own line.
|
||||
|
||||
En esta sentencia, definimos una variable `user`, y como puedes ver, esta variable se restablece durante cada iteración a cada una de las claves del objeto a medida que la sentencia hace un bucle a través del objeto, dando como resultado que el nombre de cada usuario se imprima en la consola.
|
||||
We defined the variable `food` in the loop head and this variable was set to each of the object's keys on each iteration, resulting in each food's name being printed to the console.
|
||||
|
||||
**NOTA:** Los objetos no mantienen un orden para las claves almacenadas como lo hacen los arreglos; por lo tanto, la posición de una clave en un objeto, o el orden relativo en el que aparece, es irrelevante cuando se hace referencia o se accede a esa clave.
|
||||
|
||||
# --instructions--
|
||||
|
||||
Hemos definido una función `countOnline` que acepta un argumento (un objeto usuario). Utiliza una sentencia <dfn>for...in</dfn> dentro de esta función para iterar sobre el objeto usuarios (users) pasado a la función y devuelve el número de usuarios cuya propiedad `online` esté establecida como `true`. A continuación se muestra un ejemplo de un objeto usuario que podría pasarse a `countOnline`. Cada usuario tendrá una propiedad `online` con un valor `true` o `false`.
|
||||
We've defined a function `countOnline` which accepts one argument, `allUsers`. Use a <dfn>for...in</dfn> statement inside this function to loop through the `allUsers` object and return the number of users whose online property is set to `true`. An example of an object which could be passed to `countOnline` is shown below. Each user will have an `online` property set to either `true` or `false`.
|
||||
|
||||
```js
|
||||
{
|
||||
@@ -128,7 +133,7 @@ const users = {
|
||||
}
|
||||
}
|
||||
|
||||
function countOnline(usersObj) {
|
||||
function countOnline(allUsers) {
|
||||
// Only change code below this line
|
||||
|
||||
// Only change code above this line
|
||||
@@ -140,13 +145,13 @@ console.log(countOnline(users));
|
||||
# --solutions--
|
||||
|
||||
```js
|
||||
function countOnline(usersObj) {
|
||||
let online = 0;
|
||||
for(let user in usersObj){
|
||||
if(usersObj[user].online) {
|
||||
online++;
|
||||
function countOnline(allUsers) {
|
||||
let numOnline = 0;
|
||||
for(const user in allUsers){
|
||||
if(allUsers[user].online) {
|
||||
numOnline++;
|
||||
}
|
||||
}
|
||||
return online;
|
||||
return numOnline;
|
||||
}
|
||||
```
|
||||
|
||||
Reference in New Issue
Block a user