Skip to main content

Passing Data from Controller to View in ASP.NET Core MVC

Passing Data from Controller to View in ASP.NET Core MVC

In ASP.NET Core MVC, passing data from the controller to the view is a crucial part of rendering dynamic content. There are several ways to pass data, including ViewData, ViewBag, and Model. Let's explore these methods:


1. Passing Data Using Model

The most common and recommended way to pass data from the controller to the view is by using a model.

Steps:

  1. Create a Model: Define a class that will hold the data.
  2. Pass the Model: Use the View() method in the controller to pass the model data to the view.
  3. Use the Model in the View: In the view, specify the model type and access its properties.

Example:

Step 1: Create a Model
public class Product
{
    public int Id { get; set; }
    public string Name { get; set; }
    public decimal Price { get; set; }
}
Step 2: Controller
public class ProductController : Controller
{
    public IActionResult Index()
    {
        var product = new Product
        {
            Id = 1,
            Name = "Laptop",
            Price = 899.99M
        };

        return View(product);
    }
}
Step 3: View (Index.cshtml)
@model Product

<h2>Product Details</h2>

<p>Id: @Model.Id</p>
<p>Name: @Model.Name</p>
<p>Price: @Model.Price</p>

2. Passing Data Using ViewBag

ViewBag is a dynamic object that allows you to pass data from the controller to the view.

Example:

Controller
public class ProductController : Controller
{
    public IActionResult Index()
    {
        ViewBag.ProductName = "Laptop";
        ViewBag.Price = 899.99M;

        return View();
    }
}
View (Index.cshtml)
<h2>Product Details</h2>

<p>Name: @ViewBag.ProductName</p>
<p>Price: @ViewBag.Price</p>

3. Passing Data Using ViewData

ViewData is a dictionary that allows you to pass data from the controller to the view.

Example:

Controller
public class ProductController : Controller
{
    public IActionResult Index()
    {
        ViewData["ProductName"] = "Laptop";
        ViewData["Price"] = 899.99M;

        return View();
    }
}
View (Index.cshtml)
<h2>Product Details</h2>

<p>Name: @ViewData["ProductName"]</p>
<p>Price: @ViewData["Price"]</p>

Note: You may need to cast the data to the appropriate type, e.g., @((decimal)ViewData["Price"]).


4. Passing Data Using TempData

TempData is used for passing data between actions or during a redirect.

Example:

Controller
public class ProductController : Controller
{
    public IActionResult Add()
    {
        TempData["Message"] = "Product added successfully!";
        return RedirectToAction("Index");
    }

    public IActionResult Index()
    {
        ViewBag.Message = TempData["Message"];
        return View();
    }
}
View (Index.cshtml)
<h2>Product Details</h2>

@if (ViewBag.Message != null)
{
    <p>@ViewBag.Message</p>
}

5. Passing Data via Query Parameters (URL)

You can access query parameters directly in the controller action.

Example:

Controller
public class ProductController : Controller
{
    public IActionResult Index(string productName)
    {
        ViewBag.ProductName = productName;
        return View();
    }
}
URL:
/Product/Index?productName=Laptop
View (Index.cshtml)
<h2>Product Details</h2>

<p>Product Name: @ViewBag.ProductName</p>

Summary of Methods to Pass Data from Controller to View

  • Model: Strongly-typed data, recommended for most scenarios.
  • ViewBag: Dynamic property, useful for small, non-complex data.
  • ViewData: Dictionary, similar to ViewBag but requires casting.
  • TempData: Used across actions and redirects.
  • Query Parameters: Passed in the URL, accessible in the controller.

Each method has its advantages and appropriate use cases. For most scenarios, models are the recommended approach as they provide strong typing and better maintainability.

Comments

Popular posts from this blog

Car Wash System vb.net

This software consists of a database that save the registration number of every vehicle being wash along side with the date, type of wash made and price Screen Shot Source Code To view records in the database: Dim conn As OleDbConnection = New OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=|DataDirectory|\washRcd.accdb;Persist Security Info=False") Dim sql As String sql = " SELECT * FROM tblwash" conn.Open() Dim dt As New DataTable Dim cmd2 As New OleDb.OleDbDataAdapter(sql, conn) cmd2.Fill(dt) DataGridView1.DataSource = dt DataGridView1.Refresh() conn.Close() To insert new record in the database: Private Sub insert() Dim conn As OleDbConnection = New OleDbConnection("Provider=Microsoft.ACE.OLEDB.12.0;Data Source=|DataDirectory|\washRcd.accdb;Persist Security Info=False") Dim updateSql As String = String.Format(...

Face recognition using EmguCV 3.0 and typing pattern recognition

Introduction An MSc project with the title Student Examination System, where the objective is to put the students in an examination condition but instead of having an invigilator in an examination center, the system will cater for the proper ongoing of the exam. the system can be used as an online examination system The system is able to: Recognizing the face shape of a particular student Detect if there is more than one person in the examination room  Analyze the typing pattern of a student and detect if any one person is taking part in the exam voice recognition for the student and detect if there is more than one person speaking in the examination room Setup Download Emgu CV from  http://www.emgu.com/wiki/index.php/Main_Page Download Haarcascade from  https://github.com/opencv/opencv/tree/master/data/haarcascades Create an account at  https://www.keytrac.net/ Face recognition The snippet below illustrates how the Emgu CV is loaded whe...

Student Information System - AngularJS , ASP.NET API, C#

Web based application the student information system is a small application that allows user to register and login to view information about a particular student and can perform several actions like Login and register to the application View students  Add new student Delete a particular student Update user information Screen Shot Project architecture routing.js, config.js and app.js allow the application to route from one partial view to another and config.js is used to save all the endpoint needed to access the API.   For separation of concerns, in the solution panel separate partial views, controller and services in different directories and reference it in index.html to enable angular to load all the files required Login process login.html LoginController.js Using $resource from AngularJS to make an API call and response  with a user details model UserViewModel and UserDetailsViewModel Using Unity fo...