Saturday, October 10, 2020

Creating blazor model classes

 

Creating blazor model classes


As we progress through this course we will be building Employee management system that allows us to Create, Read, Update and Delete employees. The following are the model classes we need.

  1. Employee
  2. Department
  3. Gender
// Employee class

public class Employee
{
    public int EmployeeId { get; set; }
    public string FirstName { get; set; }
    public string LastName { get; set; }
    public string Email { get; set; }
    public DateTime DateOfBrith { get; set; }
    public Gender Gender { get; set; }
    public Department Department { get; set; }
    public string PhotoPath { get; set; }
}

// Gender Enum

public enum Gender
{
    Male,
    Female,
    Other
}

// Department Class

public class Department
{
    public int DepartmentId { get; set; }
    public string DepartmentName { get; set; }
}

Create Blazor Model classes

Create a new .NET Standard Class Library project. Name the project EmployeeManagement.Models. Name the solution BlazorTutorial

creating blazor model classes

If you are wondering why we chose a .NET standard class library project. Well, it allows us to reuse these models in many different project types across the .NET ecosystem.

why use .net standard

We will be using these models in a Blazor web application project. As we progress through this course we will be creating ASP.NET core RESTful services. These services provide the data our Blazor project needs. Even in the RESTful services project we will be using these model classes.

Create Blazor Web Project

Add a new Blazor server project, to the BlazorTutorial solution Name it EmployeeManagement.Web. This is the web application project that allows us to Create, Read, Update and Delete employees. 

This project needs the model classes we created above. So add a reference to EmployeeManagement.Models project from EmployeeManagement.Web project. 

Right click and make EmployeeManagement.Web the startup project if it is not the start up project already.

Delete the following files and folders from EmployeeManagement.Web project.

  • Data folder
  • Pages/Counter.razor
  • Pages/FetchData.razor
  • Pages/Index.razor
  • Shared/SurveyPrompt.razor

Changes in Startup.cs

Rmove the following using statement

using EmployeeManagement.Web.Data;

Remove the following line from ConfigureServices() method

services.AddSingleton<WeatherForecastService>();

If you are following along, at this point your project should look as below

blazor project tutorial

Create EmployeeList component

In EmployeeManagement.Web project, right click on the Pages folder and add a new razor component. Name it EmployeeList.razor. It is this component that we will use to display the list of Employees.

Include the following @page directive in EmployeeList.razor file. This tells Blazor to render this component when we navigate to the root application URL.

@page "/"

Changes in NavMenu.razor

Remove the following 2 navigation menu items.

<li class="nav-item px-3">
    <NavLink class="nav-link" href="counter">
        <span class="oi oi-plus" aria-hidden="true"></span> Counter
    </NavLink>
</li>
<li class="nav-item px-3">
    <NavLink class="nav-link" href="fetchdata">
        <span class="oi oi-list-rich" aria-hidden="true"></span> Fetch data
    </NavLink>
</li>

No comments:

Post a Comment

Binding select element with database data in Blazor

  When the   Edit Employee   form loads, we want to retrieve the list of all departments from the database and bind them to the   Department...