How to pass data from parent component to child component using parameters in Blazor.
Let's understand this with an example.
As you can see from the image below, when Show Footer checkbox is checked, the Card Footer should be displayed when it is unchecked it should be hidden.
On this page we have 2 blazor components
- EmployeeList Component (Parent Component)
- DisplayEmployee Component (Child Component)
Child Component Class (DisplayEmployeeBase.cs)
- This class has just 2 properties (Employee and ShowFooter)
- Both of them are decorated with the Parameter attribute
- This attribute allows the values to be passed from the parent component
Child Component View (DisplayEmployee.razor)
- This component does not have @page directive. We intentionally left it out, because we are going to use this component only as a child component. We don't want this to be a routable component i.e we don't want to be able to reach this component by using a URL in the browser.
- This component binds to the Employee property to display the employee details. It also uses the ShowFooter boolean property to show and hide the footer.
- The values for these 2 properties (Employee and ShowFooter) will be passed by the parent component (EmployeeList component)
Parent Component Class (EmployeeListBase.cs)
- The main responsibility of this parent component (EmployeeList) is to retrieve the list of employees by calling the REST API.
- It also has the ShowFooter boolean property. The Show Footer checkbox on the view is bound to this property.
Parent Component View (EmployeeList.razor)
- As this parent component loops through the list of employees, it passes the employee object to the child component using the Employee property.
- A value for ShowFooter is also passed from the parent component to the child component.
- Remember both these properties (Employee and ShowFooter) are decorated with the [Parameter] attribute in the child component. This allows the parent component to pass values to those 2 properties.
No comments:
Post a Comment