'Best practice for initializing a variable when using @Input decorator in Angular
Let's assume we have an Interface Customer:
export interface Customer {
name: string;
age: number;
phone: string;
}
Now we have a parent component and we want to pass an instance of Customer to the child component:
<child-component [customer]="instanceOfCustomer"></child-component>
After that we need to use @Input decorator to get the data in the child component. (We assume passing the instance is mandatory to use this component and this component will not work without passing the instance)
@Input() customer:Customer;
The problem is that we need to initialize customer somewhere and I think there are 3 approaches to avoid the error in Typescript:
Initializing an empty
customerin the constructor:this.customer = { name: ""; age: 0; phone: ""; }Change
strictPropertyInitializationto falseJust adding the
!prefix (Which I think I should use because no one should use this child component without passing the relative customer)@Input() customer!:Customer;
I want to know what approach should I use to avoid property initialization error in case of using @Input decorator.
Solution 1:[1]
you should use setter https://angular.io/guide/component-interaction#intercept-input-property-changes-with-a-setter
or you can also use your 3rd approach.
there is already some answers for this too.
refer below answers for more details :
Solution 2:[2]
To avoid TS from complaining I'll suggest initializing it like this:
@Input() customer: Customer | null = null;
Using null will stop the compiler from complaining when you pass the input through the async pipe (the async pipe returns something like T | null).
Also by doing that you'll have to make sure that you account for null values wherever you use that property, so fewer errors to deal with in production if something goes wrong let's say.
Sources
This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.
Source: Stack Overflow
| Solution | Source |
|---|---|
| Solution 1 | Gyanendra Singh |
| Solution 2 | ionut-t |
