Yesterday, we covered ng-template
and touched on different scenarios when it makes sense to use ng-template
. Let’s now introduce a close relative of ng-template
called ng-container
.
There are a lot of similarities between those two elements, which can both be used to use structural directives such as ngIf or ngFor, with the bonus that ng-container can be used with the shorthand syntax of those directives:
data:image/s3,"s3://crabby-images/f9b0a/f9b0a78cfe25824f04bcf24a6e6d23cf4b9d072e" alt=""
One thing you probably noticed as an Angular developer is that we can’t use two structural directives on the same element:
data:image/s3,"s3://crabby-images/61d3e/61d3e4cf801385eab86674102beefa6b24109d3e" alt=""
In this scenario, using ng-container
is the perfect way to use both directives without adding any HTML to the DOM, as ng-container
, just like ng-template
, doesn’t create new DOM elements:
data:image/s3,"s3://crabby-images/2eed8/2eed856252021fb840e7242e530b27e5317bd7d1" alt=""
Another use for ng-container
is to become the host of a ng-template
, similar to the way that a router-outlet
is the host of routed components:
data:image/s3,"s3://crabby-images/0309a/0309abc8ee7ea68eed15d0e286c13abc17b1ac3d" alt=""
Such templates can be passed from a parent component using @Input
and let the child component decide when to display which template, which is very powerful:
data:image/s3,"s3://crabby-images/a7dad/a7dad22bcdb7b20b085acd3ca2d519a9d9eb4564" alt=""
You can find a complete code example of such a feature in this Stackblitz and a more in-depth tutorial here if you want to try it.