I have a json array which can contain either the component or the html selector for the component i want to load. I am trying to load this data inside a for loop. When I try to interpolate the value {{d.html}} it appears as plan text. When I use the innerHTML approach below and inspect the dom I see the html there but it does not behave as a custom component (the dom will just contain instead of initializing it and replacing it with the components template.
I have look at the dynamic content loader but that does not see to fit. This is in a for loop and therefore can not use the template syntax so loadIntoLocation will not work for me. Also not sure how it would work if the component had any input.
<div *ngFor="#d of dtabs" class="tab-pane" id="tab-{{d.component}}">
<div [innerHTML]="d.html"></div>
</div>
I also was looking for a way to do that. I saw the @guyoung answer and built something based on that. But then, I realised that
DynamicComponentLoader.loadIntoLocation()
doesn't exist anymore in the last version, andDynamicComponentLoader
is already deprecated.I read some docs and posts and created a new Directive that worked fine. Check out:
Angular2 Dynamically Render Template
full code : https://github.com/guyoung/GyPractice-Angular2Advanced/tree/master/apps/dynamically_render_template