Tutorials ASP.NET Core Tutorial

Models and ViewModels — Complete Guide

Models and ViewModels — Complete Guide: free step-by-step lesson with examples, common mistakes, and interview tips — part of ASP.NET Core Tutorial on Toolliyo Academy.

On this page

ASP.NET Core Tutorial (ShopNest) · Lesson 13 of 100

Models and ViewModels

BeginnerIntermediateAdvancedProfessional

Beginner · 1 — Foundations · ~12 min read · Module 2: MVC Fundamentals

Introduction

This lesson is part of the beginner section. We explain Models and ViewModels slowly, with examples you can copy and run. If something is unclear, read it twice — that is how everyone learns. A model represents data — often a C# class matching a database table or form. A ViewModel is a class shaped for one screen, combining fields the view needs without exposing the whole entity. Passing EF entities directly to views can over-post fields a hacker can abuse. ViewModels keep forms safe and simple.

Models and ViewModels appears in almost every web app you will build. Once it clicks, EF Core and Web API become much easier.

When will you use this?

You use this in every web page and form you build from your first app to production.

  • Product pages, login forms, and admin dashboards all use controllers, views, and models.
  • When a user submits an order form, model binding maps form fields to a C# class.

Real-world: HDFC-style net banking API

The Banking team building HDFC-style net banking API uses Models and ViewModels to separate database Product from ProductEditViewModel shown on the form. account holders never see the C# code — they just get a fast, reliable transfer endpoints and account balance.

Production-style code

// Entity
public class Product
{
    public int Id { get; set; }
    public string Name { get; set; } = "";
    public decimal CostPrice { get; set; }  // admin only
    public decimal SalePrice { get; set; }
}

// ViewModel for storefront
public class ProductCardVm
{
    public string Name { get; set; } = "";
    public decimal SalePrice { get; set; }
}

What happens in production: In HDFC-style net banking API, getting Models and ViewModels right means account holders trust the transfer endpoints and account balance every day.

Lesson example (start here)

Copy this smaller example first. Once it works, compare it with the real-world code above.

// Entity
public class Product
{
    public int Id { get; set; }
    public string Name { get; set; } = "";
    public decimal CostPrice { get; set; }  // admin only
    public decimal SalePrice { get; set; }
}

// ViewModel for storefront
public class ProductCardVm
{
    public string Name { get; set; } = "";
    public decimal SalePrice { get; set; }
}

Line-by-line walkthrough

CodeWhat it means
// EntityComment — notes for humans; the compiler ignores it.
public class ProductPart of the Models and ViewModels example — read it together with the lines before and after.
{Part of the Models and ViewModels example — read it together with the lines before and after.
public int Id { get; set; }Part of the Models and ViewModels example — read it together with the lines before and after.
public string Name { get; set; } = "";Part of the Models and ViewModels example — read it together with the lines before and after.
public decimal CostPrice { get; set; } // admin onlyPart of the Models and ViewModels example — read it together with the lines before and after.
public decimal SalePrice { get; set; }Part of the Models and ViewModels example — read it together with the lines before and after.
}Closes a block started by { above.
// ViewModel for storefrontComment — notes for humans; the compiler ignores it.
public class ProductCardVmPart of the Models and ViewModels example — read it together with the lines before and after.
{Part of the Models and ViewModels example — read it together with the lines before and after.
public string Name { get; set; } = "";Part of the Models and ViewModels example — read it together with the lines before and after.
public decimal SalePrice { get; set; }Part of the Models and ViewModels example — read it together with the lines before and after.
}Closes a block started by { above.

How it works (big picture)

  • The view only gets Name and SalePrice — not CostPrice.
  • Map from Product to ProductCardVm in the controller or a service.

Do this on your computer

  1. Create a Product class and a ProductEditVm with only form fields.
  2. Build a create form bound to ProductEditVm.
  3. Map to Product before saving to the database.
  4. Read the real-world section and name which part of the app uses this topic.
  5. Run the example locally with dotnet run and confirm the same behavior.
  6. Change one value in the example (route, text, or connection string) and predict what will happen before you save.

Experiments — try changing this

  • Change a string or route in the example and save — watch the browser or Swagger response update.
  • Break the code on purpose (remove a semicolon), read the error message, then fix it.

Remember

Model = domain/data shape. ViewModel = what one view needs. Do not expose internal fields to the browser.

Common questions

ViewModel vs DTO?

Similar idea — DTO often used for API responses; ViewModel for MVC views.

How long should I spend on Models and ViewModels?

Until you can explain it in your own words and run the example without looking at the answer. Beginners often need 30–60 minutes per new concept; setup lessons may take one afternoon.

What if I get stuck on Models and ViewModels?

Re-read the line-by-line walkthrough, check the terminal for red errors, and compare your code character-by-character with the example. Search the exact error text — someone else had it too.

Where is Models and ViewModels used in real jobs?

See the real-world section above — the same pattern appears in LMS, banking, e-commerce, and SaaS backends. Interviewers ask you to explain it using one concrete example.

ASP.NET Core Tutorial
Course syllabus
Start Here ASP.NET Core Complete Beginner's Guide
Module 1: Introduction & Setup Introduction to ASP.NET Core — Complete Guide ASP.NET Core Ecosystem — Complete Guide ASP.NET Core Architecture — Complete Guide Installing .NET SDK — Complete Guide Installing Visual Studio — Complete Guide VS Code Setup — Complete Guide ASP.NET Core Project Structure — Complete Guide The .csproj File — Complete Guide Program.cs Explained — Complete Guide Launch Settings and Configuration — Complete Guide
Module 2: MVC Fundamentals Controllers and Actions — Complete Guide Routing — Complete Guide Models and ViewModels — Complete Guide Razor Views — Complete Guide Layouts and Partial Views — Complete Guide Tag Helpers — Complete Guide Model Binding — Complete Guide Data Annotations Validation — Complete Guide Static Files Middleware — Complete Guide MVC Architecture — Complete Guide
Module 3: Services & Pipeline Dependency Injection — Complete Guide Middleware Pipeline — Complete Guide appsettings.json — Complete Guide Logging — Complete Guide Exception Handling — Complete Guide Filters — Complete Guide Action Results — Complete Guide JSON APIs in MVC — Complete Guide HttpClient — Complete Guide Enterprise Folder Structure — Complete Guide
Module 4: Entity Framework Core Introduction to EF Core — Complete Guide DbContext — Complete Guide Code First Migrations — Complete Guide CRUD with EF Core — Complete Guide LINQ Queries — Complete Guide Relationships in EF Core — Complete Guide Fluent API — Complete Guide Repository Pattern — Complete Guide Unit of Work — Complete Guide EF Core Performance — Complete Guide
Module 5: Web API & Security Building REST APIs — Complete Guide Swagger and OpenAPI — Complete Guide API Versioning — Complete Guide Authentication Basics — Complete Guide ASP.NET Core Identity — Complete Guide JWT Authentication — Complete Guide Authorization Policies — Complete Guide CORS — Complete Guide HTTPS and Data Protection — Complete Guide Input Validation — Complete Guide
Module 6: Advanced Features Minimal APIs — Complete Guide Background Services — Complete Guide Caching — Complete Guide SignalR Basics — Complete Guide File Upload — Complete Guide Health Checks — Complete Guide Rate Limiting — Complete Guide Clean Architecture Intro — Complete Guide CQRS with MediatR — Complete Guide AutoMapper — Complete Guide
Module 7: Testing & Quality Unit Testing with xUnit — Complete Guide Integration Testing — Complete Guide Mocking with Moq — Complete Guide API Testing with Postman — Complete Guide Test-Driven Development — Complete Guide Load Testing Basics — Complete Guide Debugging Techniques — Complete Guide Structured Logging — Complete Guide Error Handling Patterns — Complete Guide Code Quality Tools — Complete Guide
Module 8: Deploy & Cloud Publishing to IIS — Complete Guide Docker for ASP.NET Core — Complete Guide Azure App Service — Complete Guide Azure SQL Database — Complete Guide Secrets Management — Complete Guide GitHub Actions CI/CD — Complete Guide Output Caching — Complete Guide Response Compression — Complete Guide .NET 8 and .NET 9 Features — Complete Guide Production Checklist — Complete Guide
Module 9: Portfolio Projects Blog Application Project — ShopNest Project Student Portal Project — ShopNest Project Job Portal API Project — ShopNest Project E-Commerce API Project — ShopNest Project Inventory System Project — ShopNest Project Task Manager API Project — ShopNest Project Real-Time Chat Project — ShopNest Project Hospital Appointment Project — ShopNest Project Banking Dashboard API Project — ShopNest Project Multi-Tenant SaaS Project — ShopNest Project
Module 10: Professional Topics Microservices Introduction — ShopNest Project Message Queues — ShopNest Project gRPC Basics — ShopNest Project Blazor Server Intro — ShopNest Project GraphQL Basics — ShopNest Project Enterprise API Design — ShopNest Project Performance Tuning — ShopNest Project Security Hardening — ShopNest Project Full-Stack Architecture — ShopNest Project ASP.NET Core Career Roadmap — ShopNest Project
Toolliyo Assistant
Ask about tutorials, ebooks, training, pricing, mentor services, and support. I use public site content only—not admin or internal tools.

care@toolliyo.com

Need callback? Share your details