Parent to Child
Communication between Parent to Child is so easy in angular it can be achieved using
@INPUT decorator /custom property.
@INPUT decorator tells the compiler that whatever value is coming from the parent component with the same name will initialise this property decorated with @Input() decorator.
Let’s get started with a simple example to get a clear idea of it.
We have to create two component at first
1) Parent Component <parent-component></parent-component>
2) Child Component <child-component></child-component>
Example Definition: In the parent component, we have a button and on that button click we want to assign value to the property of the child component.
Step 1: Create a button in the parent component.html file with its click event.
data:image/s3,"s3://crabby-images/dcafd/dcafd67ea1dc922410e9e2da0fb8b2d4806219c4" alt=""
Step 2: Create 1 property and assign value to it in button’s click event in parent .ts file
data:image/s3,"s3://crabby-images/d2149/d214955eef48587b52ff96205eb0269bac4e78b6" alt=""
Step 3: Add the child component to the parent component.
-Here CompanyName is the Custom Property
-And CompanyNameVal is the name of the property in the parent class itself, which is used to assign value to the Custom Property.
data:image/s3,"s3://crabby-images/cca91/cca91c338161c6052f368107784674ec43e829f8" alt=""
Step 4: In child component.ts
data:image/s3,"s3://crabby-images/7b97e/7b97e34a325b284dae203094388e5e40f57a4b01" alt=""
Step 5: Add a custom property in child component.html
data:image/s3,"s3://crabby-images/828e5/828e54af5c9c425e08fcf4382c3ef2063bc218fa" alt=""
Output when Button is not clicked:
data:image/s3,"s3://crabby-images/e7612/e7612a56c10e0280a514a7f936692934d2b2d76c" alt=""
Output when Button is clicked:
data:image/s3,"s3://crabby-images/1061a/1061af1fb5079c4daeecb906d9c06a2f326ebeaf" alt=""
*******************
Child to Parent
Communication between Parent to Child is done by the @INPUT decorator. Similarly, Child to Parent is done by @OUTPUT decorator/ custom event.
@Output binds a property of the type of angular EventEmitter class. So for sending data from Child to parent we need to import 2 classes
1. Output
2. EventEmitter
Let’s get started with a simple example to get a clear idea of it
Here also we need two component i.e
1) Parent Component <parent-component></parent-component>
2) Child Component <child-component></child-component>
Example Definition: In the child component, we have a button and on that button click we want to assign value to the property of the parent component. (just reverse of @input example)
Step 1: Create button in child component.html file with its click event.
data:image/s3,"s3://crabby-images/e368f/e368ff18ba4000a8c2f3bb1570e0397753b0114b" alt=""
Step 2: Create an output decorator with EventEmitter
data:image/s3,"s3://crabby-images/e1ee0/e1ee01c2bf2c6dcea4041d8d1238711f5473e8ea" alt=""
Step 3: On button’s click emits the output decorator.
data:image/s3,"s3://crabby-images/54c24/54c24302d921119936a8edbb28cc2773c8bfbc9f" alt=""
Step 4: In parent, component.html add a child component with a custom event.
Step5: In Parent, component.ts add the custom event
data:image/s3,"s3://crabby-images/63631/63631a146743894e45976d5c852e7b5ac654465e" alt=""
Output when child component’s button is not clicked:
data:image/s3,"s3://crabby-images/130ed/130ed8f958384f0b68ee7c95be9eb21bfb8ded4d" alt=""
Output when child button is clicked:
data:image/s3,"s3://crabby-images/b5e10/b5e101bbeb0b49b3a331d69c216fe899d285fde2" alt=""
Note: Always @Input or @Output decorator will be written on the child component.
For In Input decorator, the custom property is used and for output, a custom event is used.