• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

492
Vistas
Usando 'esto' dentro de una devolución de llamada de observador

Tengo una aplicación Angular que acabo de actualizar de v8 a v12.

La forma en que manejé las respuestas a los observables ahora está obsoleta y, aunque cambié mi código, 'esto' ya no funciona dentro de la devolución de llamada y me pregunto cuál es el mejor enfoque para resolver esto.

Así es como solía manejar los observables;

 this._trialService.currentTrial().subscribe(trial => { this.trial = trial; this.loadVisitDetails() }, error => { this._alertService.showWarningAlert(error.error.title); });

Lo he cambiado a esto;

 this._trialService.currentTrial().subscribe({ next(trial) { this.trial = trial; this.loadVisitDetails() }, error(error) { this._alertService.showWarningAlert(error.error.title); } });

Debido a que el código ya no usa funciones de flecha, this ya no se refiere a la clase principal, por lo que ya no puedo acceder a las propiedades y métodos en esa clase principal.

¿Hay alguna manera de evitar esto, o tendré que crear una variable fuera de la devolución de llamada que se refiera a this ?

 const self = this; this._trialService.currentTrial().subscribe({ next(trial) { self.trial = trial; self.loadVisitDetails() }, error(error) { self._alertService.showWarningAlert(error.error.title); } });

Eso parece un poco desordenado.

about 3 years ago · Juan Pablo Isaza
1 Respuestas
Responde la pregunta

0

Todavía puede usar funciones de flecha para los controladores:

 this._trialService.currentTrial().subscribe({ next: (trial) => { this.trial = trial; this.loadVisitDetails() }, error: (error) => { this._alertService.showWarningAlert(error.error.title); } });
about 3 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda