Fully documented lesson at
In this episode, I am going to show you four different ways to share data between Angular components.
Parent to Child the Input Decorator
When you declare a variable with the Input decorator in the child component, it allows that variable to be received from a parent template. In this case, we define a message variable in the parent, then use square brackets to pass the data to the child. Now the child can display this data in its own template.
Child to Parent via ViewChild
ViewChild allows a one component to be injected into another, giving the parent access to its attributes and functions. One caveat, however, is that child won’t be available until after the view has been initialized. This means we need to implement the AfterViewInit lifecycle hook to receive the data from the child.
In the AfterViewInit function we can access the message variable defined in the child
Child to Parent via Output and EventEmitter
Another way to share data is to emit data from the child, which can be listed to by the parent. This approach is ideal when you want to share data changes that occur on things like button clicks, form entires, and other user events.
In the child, we declare a messageEvent variable with the Output decorator and set it equal to a new event emitter. Then we create a function named sendMessage that calls emit on this event with the message we want to send. Lastly, we create a button to trigger this function.
In the parent, we create a function to receive the message and set it equal to the message variable.
The parent can now subscribe to this messageEvent that’s outputted by the child component, then run the receive message function whenever this event occurs.
Share data between any components
When passing data between components that lack a direct connection, such as siblings, grandchildren, etc, you should you a shared service. When you have data that should aways been in sync, I find the RxJS `BehaviorSubject` very useful in this situation. The main benefit that a BehaviorSubject ensures that every component consuming the service receives the most recent data.
In the service, we create a private BehaviorSubject that will hold the current value of the message. We define a currentMessage variable handle this data stream as an observable that will be used by the components. Lastly, we create function that calls next on the BehaviorSubject to change its value.
The parent, child, and sibling components all receive the same treatment. We inject the DataService in the constructor, then subscribe to the currentMessage observable and set its value equal to the message variable.
Now if we create a function in any one of these components that changes the value of the message. when this function is executed the new data it’s automatically broadcast to all other components.
That’s it for data sharing. See you next time.
1 view
13
1
1 month ago 00:07:36 1
The Best Way To Scrape Yellow Pages To Generate Leads | SMMA Outreach Secrets
1 month ago 00:07:28 1
Hair Transplant in Jaipur | Best Results & Cost of Hair Transplant in Jaipur
1 month ago 00:06:27 1
Hair Transplant in Jodhpur | Best Results & Cost of Hair Transplant in Jodhpur
1 month ago 00:06:17 1
Hair Transplant in India | Best Results & Cost of Hair Transplant in India
1 month ago 00:07:38 1
Hair Transplant in Vizag | Best Results & Cost of Hair Transplant in Vizag
1 month ago 00:06:26 1
Những kỹ thuật tốt nhất để cắt và may cổ áo này | tự thiết kế cổ áo đẹp
1 month ago 00:03:40 1
Hair Transplant in Coimbatore | Best Results & Cost of Hair Transplant in Coimbatore
1 month ago 00:01:50 1
Lady Dina: Over 50 Mature Model | Wiki and Biography
1 month ago 00:08:35 1
Hair Transplant in Bikaner | Best Results & Cost of Hair Transplant in Bikaner
1 month ago 00:07:47 1
Hair Transplant in Gurgaon | Best Results & Cost of Hair Transplant in Gurgaon
1 month ago 00:03:11 1
Hair Transplant in Kolkata | Best Results & Cost of Hair Transplant in Kolkata
1 month ago 00:05:47 1
Hair Transplant in Australia | Best Results & Cost of Hair Transplant in Australia
1 month ago 00:06:32 1
Hair Transplant in Thane | Best Results & Cost of Hair Transplant in Thane
1 month ago 00:06:14 1
Hair Transplant in Firozpur | Best Results & Cost of Hair Transplant in Firozpur
1 month ago 00:03:25 1
Hair Transplant in Pune | Best Results & Cost of Hair Transplant in Pune
1 month ago 01:23:43 1
Мои добавления в подробный разбор ошибок Максвелла в его трактате , 10 мая 2024 года