Introducción
En este laboratorio, exploraremos una función de JavaScript que aplana un objeto con las rutas para las claves. La función utiliza la recursividad y Object.keys() combinada con Array.prototype.reduce() para convertir cada nodo hoja en un nodo de ruta aplanada. Al final de este laboratorio, tendrás una mejor comprensión de cómo manipular objetos de JavaScript y aplanarlos para un procesamiento de datos más fácil.
Aplanando un objeto
Para aplanar un objeto con rutas para las claves, siga estos pasos:
- Abra la Terminal/SSH y escriba
nodepara comenzar a practicar la codificación. - Utilice la recursividad para aplanar el objeto.
- Utilice
Object.keys()combinado conArray.prototype.reduce()para convertir cada nodo hoja en un nodo de ruta aplanada. - Si el valor de una clave es un objeto, llame a la función recursivamente con el
prefixadecuado para crear la ruta utilizandoObject.assign(). - De lo contrario, agregue el par clave-valor prefiijado adecuado al objeto acumulador.
- Omita el segundo argumento,
prefix, a menos que desee que cada clave tenga un prefijo.
A continuación, se muestra una implementación de ejemplo:
const flattenObject = (obj, prefix = "") =>
Object.keys(obj).reduce((acc, k) => {
const pre = prefix.length ? `${prefix}.` : "";
if (
typeof obj[k] === "object" &&
obj[k] !== null &&
Object.keys(obj[k]).length > 0
) {
Object.assign(acc, flattenObject(obj[k], pre + k));
} else {
acc[pre + k] = obj[k];
}
return acc;
}, {});
Puede usar la función flattenObject de la siguiente manera:
flattenObject({ a: { b: { c: 1 } }, d: 1 }); // { 'a.b.c': 1, d: 1 }
Resumen
¡Felicitaciones! Has completado el laboratorio de Aplanar Objeto. Puedes practicar más laboratorios en LabEx para mejorar tus habilidades.