this en JavaScript

Clase 78 de 80Curso de JavaScript Desde Cero

Contenido del curso

Primeros Pasos

Funciones y This

Resumen

Comprender la palabra reservada this es fundamental para trabajar con clases, funciones constructoras e instancias en JavaScript. Su función principal es dar referencia al objeto que se está construyendo, permitiendo que las propiedades y métodos se conecten correctamente con cada instancia creada.

¿Qué significa this dentro de una clase?

This es una palabra reservada que apunta al objeto mismo que se está construyendo a partir de una clase. Cuando definimos una clase, estamos creando un molde del cual se generarán múltiples instancias, es decir, objetos individuales con sus propios valores. Dentro de ese molde, this permite que cada instancia reciba y almacene los datos que le corresponden [0:30].

Sin this, no habría forma de vincular los valores que se pasan al constructor con las propiedades del objeto resultante. Es el puente entre los parámetros que recibe el constructor y las propiedades que tendrá el objeto final.

¿Cómo se usa this en el constructor de una clase?

Veamos un ejemplo práctico. Se crea una clase Persona con un método constructor que recibe nombre y edad [1:05]:

javascript class Persona { constructor(nombre, edad) { this.nombre = nombre; this.edad = edad; } }

  • this.nombre = nombre significa: la propiedad nombre de este objeto será igual al valor que se pase como argumento.
  • this.edad = edad funciona de la misma manera para la edad.

El constructor es un método especial dentro de la clase que se ejecuta automáticamente cada vez que se crea una nueva instancia con la palabra reservada new.

¿Cómo se crea una instancia a partir de la clase?

Para generar un objeto concreto a partir del molde, se utiliza new seguido del nombre de la clase y los valores correspondientes [1:40]:

javascript const persona1 = new Persona("Alice", 25); console.log(persona1);

Al ejecutar esto, el resultado es un objeto con las propiedades nombre: "Alice" y edad: 25. La palabra new toma los valores proporcionados, los inyecta como parámetros del constructor y this se encarga de asignarlos al objeto que se está creando.

¿Cómo funciona this dentro de un método de instancia?

Si necesitamos agregar un método particular a una instancia específica, this sigue cumpliendo la misma función: hacer referencia al objeto actual [2:40].

javascript persona1.nuevoMetodo = function() { console.log(Mi nombre es ${this.nombre}); };

persona1.nuevoMetodo();

El resultado es "Mi nombre es Alice", porque this.nombre dentro del método apunta a la propiedad nombre de persona1, que ya tiene el valor "Alice" asignado desde el constructor [3:10].

¿Por qué es tan importante entender this?

La referencia que establece this es lo que permite que cada instancia sea independiente. Si creamos persona2 con otros valores, this dentro de esa instancia apuntará a sus propias propiedades, no a las de persona1.

  • This siempre hace referencia al objeto en el que se está ejecutando el código.
  • Dentro del constructor, this representa la instancia que se está creando en ese momento.
  • Dentro de un método, this apunta al objeto que invoca dicho método.

El concepto de instancia se refiere a cada objeto individual que se genera a partir de una clase. La clase actúa como un molde y cada instancia es una copia con valores propios. Por su parte, el operador new es el mecanismo que activa el constructor y produce esa nueva instancia.

Dominar this es esencial para construir aplicaciones con programación orientada a objetos en JavaScript. Si tienes dudas sobre cómo se comporta en diferentes contextos, comparte tu experiencia en los comentarios.