π΄ Typed ContextOutlet
Information
You can improve template type checking for custom directives by adding template guard properties to your directive definition. Angular offers the static function ngTemplateContextGuard
to strongly type structural directives.
However, the context of NgTemplateOutlet type is Object. But with the help of the above guard, we can improve that behavior.
Statement
In this exercise, we want to learn how to strongly type our ng-template
in our AppComponent
.
This exercise has two levels of complexity.
Level 1: Known Interface
Currently, we have the following piece of code.
As we can see, name
is of type any
. We want to infer the correct type using the custom directive PersonDirective
.
Level 2: Generic Interface
Currently, we have the following piece of code.
As we can see, student
is of type any
. We want to infer the correct type using the custom directive ListDirective
.
But in this part, we want to pass a list of any object to ListComponent
. And we still want the correct type to be inferred.