En este post te voy a mostrar a convertir un objeto o diccionario a un arreglo o array en JavaScript.
Vamos a repasar 3 funciones:
Tema de la captura: SynthWave ’84.
Esas funciones nos van a servir para convertir un objeto a arreglo en JavaScript de 3 formas. El primero extrayendo cada clave y valor como un nuevo arreglo, el segundo extrayendo únicamente los valores y el tercero obteniendo únicamente las claves.
Comencemos viendo el método entries. Este método crea un nuevo arreglo de arreglos, en donde cada valor del arreglo es otro arreglo con dos valores.
El primer valor es la clave y el segundo el valor (suena confuso pero no lo es). Veamos un ejemplo:
/**
* Convertir un objeto a un arreglo
* en JavaScript
*
* @author parzibyte
*
* https://parzibyte.me/blog
*/let alumnosConCalificaciones = {
"Luis": 100,
"Pedro": 90,
"María José": 100,
"John Galt": 99
};
// Object.entries convierte tanto clave y valor. Cada
// par es convertido a un arreglo. Al final tenemos un array de arrays
let arregloDeClavesYValores = Object.entries(alumnosConCalificaciones);
console.log("Claves y valores: ", arregloDeClavesYValores);
/*
Salida:
Claves y valores: [ [ 'Luis', 100 ],
[ 'Pedro', 90 ],
[ 'María José', 100 ],
[ 'John Galt', 99 ] ]
*/
Como ves, el objeto se ha convertido en un arreglo. Cada entrada del arreglo tiene un nuevo arreglo; en el índice 0
tiene la clave del objeto (el nombre del alumno) y en el índice 1
la calificación del mismo.
Para extraer únicamente las claves del objeto podemos usar el método Object.keys
. Como su nombre lo dice, pondrá cada clave del objeto dentro de un arreglo.
Al final tendremos un arreglo de valores, valores que eran las claves del objeto anteriormente.
Veamos el ejemplo:
/**
* Convertir un objeto a un arreglo
* en JavaScript
*
* @author parzibyte
*
* https://parzibyte.me/blog
*/let alumnosConCalificaciones = {
"Luis": 100,
"Pedro": 90,
"María José": 100,
"John Galt": 99
};
// Object.keys toma las claves, para este ejemplo serían
// los nombres de alumnos
let alumnos = Object.keys(alumnosConCalificaciones);
console.log("Claves: ", alumnos);
/*Salida:
Claves: [ 'Luis', 'Pedro', 'María José', 'John Galt' ]
*/
En este caso tenemos como resultado un arreglo de cadenas, pues son las claves del objeto o, en otras palabras, los nombres de los alumnos.
Ahora veamos el tercer ejemplo. El método Object.values
toma todos los valores del objeto (no las claves) y los coloca dentro de un arreglo.
Veamos su uso:
/**
* Convertir un objeto a un arreglo
* en JavaScript
*
* @author parzibyte
*
* https://parzibyte.me/blog
*/let alumnosConCalificaciones = {
"Luis": 100,
"Pedro": 90,
"María José": 100,
"John Galt": 99
};
// Object.values toma los valores, para este ejemplo serían
// las calificaciones
let calificaciones = Object.values(alumnosConCalificaciones);
console.log("Valores: ", calificaciones);
/*Salida:
Valores: [ 100, 90, 100, 99 ]
*/
Ahora la salida son los valores, que en este caso son las calificaciones.
Cabe mencionar que estos métodos funcionan mejor en navegadores modernos.
Nota: estos ejemplos corren en el navegador y en Node.JS. Es decir, del lado del cliente y del servidor.
En mi blog puedes encontrar más sobre JavaScript moderno.
Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…
En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…
En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…
Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…
En este artículo te voy a enseñar cómo usar un "top level await" esperando a…
Ayer estaba editando unos archivos que son servidos con el servidor Apache y al visitarlos…
Esta web usa cookies.