DEV Community

loading...
Cover image for Desestructuración de objetos anidados

Desestructuración de objetos anidados

neon_affogato profile image Eduardo Zepeda Originally published at coffeebytes.dev ・2 min read

En las entradas anteriores expliqué brevemente como llevar a cabo una desestructuración de objetos bastante simples, pero en la mayoría de los casos no tendremos la suerte de trabajar con objetos planos, sino que nos encontraremos con objetos anidados con varios niveles de profundidad. ¿Tendremos que conformarnos con olvidarnos de esta característica y hacer el trabajo explícitamente asignando una constante a cada objeto? Por suerte Javascript permite trabajar la desestructuración de objetos anidados.

Creemos un ejemplo de objeto para probar.

const user = {
  userIsLoggedIn: true, 
  data: {
    email: "email@example.org", 
    name:"Isabel", 
    lastName:"Allende", 
    location:{
      state: "Lima", 
      country: "Peru", 
      postalCode: "15048"
    }
  }
}
Enter fullscreen mode Exit fullscreen mode

Obtengamos primero la propiedad userIsLoggedIn

const { userIsLoggedIn } = user
userIsLoggedIn
true
Enter fullscreen mode Exit fullscreen mode

¿Pero y si ahora queremos asignar la propiedad state? Para lograrlo primero pensemos en la estructura del objeto. Nuestro objeto tiene tres niveles; en el primero, está userIsLoggedIn y data; en el segundo, email, name, lastName y location; en el tercer nivel, las propiedades state, country y postalCode. Es en este último nivel donde está la propiedad que intentamos desestructurar.

const user = {
  userIsLoggedIn: true, 
  data: {
    email: "email@example.org", 
    name:"Isabel", 
    lastName:"Allende", 
    location:{
      state: "Lima", 
      country: "Peru", 
      postalCode: "15048"
    }
  }
}
Enter fullscreen mode Exit fullscreen mode

El primer nivel es data, por lo que colocaremos dos puntos ":" ahí y seguiremos descendiendo hasta el nivel deseado . Dejemos pendiente el resto asignándole un "{...}". Si estás siguiendo este ejemplo no le des ENTER hasta el final.

const {data:{...}}
Enter fullscreen mode Exit fullscreen mode

El segundo nivel que nos lleva a nuestra propiedad state es location. Por lo que extendemos nuestra asignación anterior:

const {data:{location:{...}}}
Enter fullscreen mode Exit fullscreen mode

Nuestra proppiedad state se encuentra en el tercer nivel, por lo que ya no hay que descender más, simplemente colocamos la constante a continuación.

const {data: {location:{state}}}=user
state
"Lima"
Enter fullscreen mode Exit fullscreen mode

Ahora sí ya puedes darle ENTER, cuando accedas a la constante state, verás que hace referencia a la propiedad state, anidada del objeto.

Accediendo a más de una propiedad

El ejemplo anterior no estuvo tan complicado, pero que tal si en lugar de una sola propiedad queremos desestructurar el valor de userIsLoggedIn, email y state.

Para hacer lo anterior bastaría con que ubicaramos en que nivel se encuentran la propiedades que queremos desestructurar e incluirlas en el nivel adecuado en nuestra sentencia de código pasado:

const {userIsLoggedIn, data: {email, location:{state}}}=user
userIsLoggedIn
true
email
"email@example.org"
state
"Lima"
Enter fullscreen mode Exit fullscreen mode

En la siguiente entrada hablaré sobre como asignar valores por defecto al desestructurar objetos.

Sígueme en Twitter aquí

Sígueme en twitter, publico un tweet cada que tengo una nueva entrada. Además Twitteo frecuentemente información interesante sobre tecnología que puede servirte.

Discussion

pic
Editor guide