AnswerBun.com

Error con @viewChild con renderer2

Stack Overflow en español Asked by Mateo Morales on January 5, 2022

En el archivo index.html tengo lo siguiente

 <body #body>
  <app-root></app-root>
</body>

y en otro componente quiero tomar el body y asignarle una clase al body

 @ViewChild("body") body: ElementRef
constructor(private render: Renderer2  ) {}

  ngOnInit(): void {
    this.render.addClass(this.body.nativeElement,"login-body")
  }

pero tengo el siguiente error core.js:4196 ERROR TypeError: Cannot read property ‘nativeElement’ of undefined

2 Answers

Una solución sería utilizar document.body directamente para asignar la clase, es decir:

index.html

<body>
  <app-root></app-root>
</body>

Componente

export class MyAwesomeComponent implements OnInit, OnDestroy {

  constructor(
    private renderer: Renderer2
  ) { }

  ngOnInit() {
    this.renderer.addClass(document.body, 'awesome-class');
  }

  ngOnDestroy() {
    this.renderer.removeClass(document.body, 'awesome-class');
  }

}

En este caso, hacerlo dentro de ngOnInit es válido ya que el body está renderizado.

Answered by RRGT19 on January 5, 2022

En si, tienes dos errores, el viewchild buscara los elementos hijo del componente, obviamente el body es muy superior, te recomiendo usar algo mas nativo de javascript, lo otro es que deberias implementar esto en el AfterViewInit que es cuando un elemento esta renderizado

class MyComponent implements AfterViewInit {
  ngAfterViewInit() {
    // ...
  }
}

Answered by Samir Llorente on January 5, 2022

Add your own answers!

Related Questions

Como obtener el id de un un grupo de botones con JS?

2  Asked on October 11, 2020 by yasser-chacon

   

Tengo problemas con mi APK de produccion que genere con React Native

0  Asked on October 11, 2020 by jhon-dember-murillo-mendez

   

C# Ayuda, tengo un bug en un juego y no se solucionarlo Unity

2  Asked on October 10, 2020 by juanchi-benitez

     

Ejercicios de Arrays

4  Asked on October 10, 2020 by antonela-alde

   

DataTables 650k muy lento. Server-side funciona?

0  Asked on October 5, 2020 by lautaro

   

Eliminar la ultima coma de un foreach, Laravel

1  Asked on October 5, 2020 by miguel

   

Verificar que un valor existen en un JSON localStorage

1  Asked on October 4, 2020 by carlos-roberto-luna-ochoa

     

Bottom Sheet Android [peekHeight] no funciona en Android 6

0  Asked on October 2, 2020 by luis-eduardo-moreno

         

Cross validation en R

1  Asked on October 2, 2020 by la_roca

   

Cambiar Id de Proyecto en Android Studio

1  Asked on October 1, 2020 by nikjoseba

       

Obtener ultimo registro guardado en una tabla con relación 1 a N

2  Asked on September 30, 2020 by juan-pinzn

   

Problemas entre componentes en Angular

0  Asked on September 29, 2020 by andres-bonilla

         

Comportamiento extraño de páginas aspx

0  Asked on September 27, 2020 by volar-2016

 

Problema con algoritmo en Ruby

2  Asked on September 27, 2020 by diesan-romero

     

¿Cómo desloguerase de conexión ssh con paramiko?

1  Asked on September 25, 2020 by armel-guido

   

Como guardar tarjetas de un cliente MercadoPago sdk Nodejs

0  Asked on September 24, 2020 by facundo-rotger

     

Ask a Question

Get help from others!

© 2023 AnswerBun.com. All rights reserved. Sites we Love: PCI Database, UKBizDB, Menu Kuliner, Sharing RPP