Tipos y variables en hoisting

| Última modificación: 23 de mayo de 2024 | Tiempo de Lectura: 2 minutos

Algunos de nuestros reconocimientos:

Premios KeepCoding

¿Sabes en qué consisten los tipos y variables en hoisting? Cuando se trabaja con JavaScript, es crucial comprender cómo las variables y declaraciones de funciones se comportan en relación con el hoisting y, por eso, en este artículo profundizamos en el tema.

El hoisting es una característica peculiar de JavaScript que indica cómo se tratan las declaraciones de variables y funciones durante la fase de compilación. En pocas palabras, JavaScript mueve todas las declaraciones al comienzo de su alcance antes de ejecutar el código real. Esto puede conducir a resultados inesperados si no se comprende correctamente.

Tipos y variables en hoisting

Declarando variables con var, let y const

En JavaScript hay tres formas de declarar variables: var, let y const. Cada una tiene un comportamiento diferente en relación con el hoisting.

  1. var: cuando se declara una variable con var, esta se mueve al principio de su función o, si está fuera de una función, al principio del ámbito global. Esto crea una zona muerta temporal en la que la variable existe, pero su valor es undefined hasta que se alcance la línea en la que se declara.
  2. let: las variables declaradas con let también son hoisteadas, pero, a diferencia de var, no tienen una zona muerta temporal. En cambio, su valor se mantiene sin definir hasta que se alcanza la línea de declaración. Esto significa que let tiene un alcance de bloque.
  3. const: al igual que let, const también tiene un alcance de bloque y no tiene una zona muerta temporal. La diferencia clave radica en que las variables declaradas con const son inmutables, es decir, su valor no puede ser reasignado una vez que se ha inicializado.
Tipos y variables en hoisting

¿Cómo afecta el hoisting a las variables?

El hoisting puede causar confusión en el código y conducir a errores si no se tiene en cuenta. Veamos un ejemplo para entenderlo mejor:

//tipos y variables en hoisting
console.log(color); // Output: undefined
var color = "blue";

En este caso, la variable color es hoisteada y existe en la función o el ámbito global, pero su valor es undefined hasta que se llega a la línea de declaración. Por lo tanto, el console.log muestra undefined.

//tipos y variables en hoisting
console.log(name); // Error: name is not defined
let name = "John";

En este ejemplo, como hemos utilizado let, no hay zona muerta temporal y la variable name no está disponible antes de su declaración. Por eso, se produce un error.

El hoisting es una característica importante de JavaScript que puede afectar al comportamiento de nuestras variables y funciones. Es fundamental entender cómo var, let y const se comportan con el hoisting para escribir código limpio y libre de errores.

Si deseas sumergirte en el apasionante mundo del desarrollo web y aprender más sobre conceptos como el hoisting y muchos otros, además de sobre tipos y variables en hoisting, te recomendamos unirte al Desarrollo Web Full Stack Bootcamp. En este programa intensivo, te sumergirás en un ambiente de aprendizaje práctico y completo, para adquirir habilidades en frontend y backend, en tecnologías punteras, como React, Node.js, y mucho más.

Al superar el bootcamp, estarás listo para enfrentarte a los desafíos del sector tecnológico, una industria con una creciente demanda de profesionales. ¡Pide información ahora y únete a KeepCoding para cambiar tu vida en poco tiempo!

Alberto Casero

Alberto Casero es CTO en Watium, Fundador de Kas Factory & Coordinador del Bootcamp en Desarrollo Web.

Posts más leídos

¡CONVOCATORIA ABIERTA!

Desarrollo web

Full Stack Bootcamp

Conviértete en Full Stack Deeveloper en solo 10 meses. Accede a un sector con el 98,49% de empleabilidad con sueldos de hasta 80K.