Currently I'm working in a view where I have to dynamically create HTML elements.
I'm creating the HTML elements with *ngFor directive bounded with an Array.
I need to refer the new HTML element with JQuery selector after push a new object into the Array, but the HTML element is not rendered yet.
How can I trigger a function just after the HTML element is ready ?
Thanks in advance.
As pointed out in the comments, you probably don't want to use JQuery on Angular DOM elements if you have a choice. It will lead to endless confusion.
You can, however, access a component's DOM children using
elementRef.nativeElement
. The lifecycle hook where you want to run that in the case of*ngFor
(or other structural directives) isAfterViewChecked
. At that point, you know that the component has finished binding and rendering its content.Combined, here's a cheap little example just coloring all dynamically generated divs of a component:
You can follow below steps inside the component:-
The whole logic is that ngAfterViewInit() works when the HTML is fully loaded and you have to do something on that HTML. For example your view has some static HTML and some external JS files are creating some HTML elements inside some div dynamically. So first you will load your view using ngOnInit() and then using external JS you can create and bind html elements dynamically to that div.
I hope this helps you.
All the best.