What is route parameters in Blazor ? Explain with example.
The following EmmployeeList component displays the list of all employees.
When we click the View button, the user should be redirected to the URL (/employeedetails/3). The value 3 in the URI is the employee id. The blazor component (EmployeeDetails) displays the details of the Employee.
EmployeeDetails.razor
To get to this component, employee Id must be passed in the URL as a route parameter. This is specified using the @page directive route template.
EmployeeDetailsBase.cs
- The Id public property is decorated with the [Parameter] attribute.
- The name of the property (Id) matches with the name of the route parameter in the @page directive (@page "/employeedetail/{Id}")
- The blazor router, uses the route parameter value in the URL to populate the Id property in the component class.
- The following 2 conditions must be true, for the router to be able to map the route parameter value in the URL to the public property in the component class
- The public property in the component class must be decorated with [Parameter] attribute.
- The name of the property in the component class and the name of the route parameter in the @page directive must be the same.
If the names are different you will get the following runtime exception
InvalidOperationException: Object of type 'EmployeeManagement.Web.Pages.EmployeeDetail' does not have a property matching the name 'Id'.
Blazor optional route parameter
Optional parameters aren't supported. However, we can use two @page directives to get the effect of optional parameters.
The first @page directive allows navigation to the component without a parameter. The second @page directive receives the {Id} route parameter and assigns the value to the Id public property on the component class.
Building URL with route parameter
On the list page when the View button is clicked we want to redirect the user to /employeedetail/id.
IEmployeeService.cs
EmployeeService.cs
public class EmployeeService : IEmployeeService { private readonly HttpClient httpClient; public EmployeeService(HttpClient httpClient) { this.httpClient = httpClient; } public async Task<Employee> GetEmployee(int id) { return await httpClient.GetJsonAsync<Employee>($"api/employees/{id}"); } public async Task<IEnumerable<Employee>> GetEmployees() { return await httpClient.GetJsonAsync<Employee[]>("api/employees"); } }
No comments:
Post a Comment