Thursday, August 15, 2019

Creating a MVC Layout page

The final step for using Bootstrap 4 in your ASP.NET MVC project is to create a Layout page that will contain all the necessary CSS and JavaScript files in order to include Bootstrap components in your pages. To create a Layout page, follow these steps:
  1. Add a new sub folder called Shared to the Views folder.
  2. Add a new MVC View Layout Page to the Shared folder. The item can be found in the .NET Core | Server-side category of the Add New Item dialog.
  3. Name the file _Layout.cshtml and click on the Add button:
  4. With the current project layout, add the following HTML to the _Layout.cshtml file:
    <!DOCTYPE html>
    <html lang="en"><head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no"> initial-scale=1, shrink-to-fit=no"><meta http-equiv="x-ua-compatible" content="ie=edge"><title>@ViewBag.Title</title><link rel="stylesheet" href="~/css/bootstrap.css" /></head><body> @RenderBody()<script src="~/lib/jquery/dist/jquery.js"></script><script src="~/lib/bootstrap/dist/js/bootstrap.js"></script></body></html> @{
    Layout = "_Layout";
    }
    Content Delivery Networks
    <script src="https://code.jquery.com/jquery-3.1.0.js"></script> <script src="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-alpha.2/js/bootstrap.min.js"></script> Note
    x
    x
  5. Finally, add a new MVC View Start Page to the Views folder called _ViewStart.cshtml. The _ViewStart.cshtml file is used to specify common code shared by all views.
  6. Add the following Razor markup to the _ViewStart.cshtml file:
  7. In the preceding mark-up, a reference to the Bootstrap CSS file that was generated using the Sass source files and Gulp is added to the <head> element of the file. In the <body> tag, the @RenderBodymethod is invoked using Razor syntax.
  8. Finally, at the bottom of the file, just before the closing </body> tag, a reference to the jQuery library and the Bootstrap JavaScript file is added. Note that jQuery must always be referenced before the Bootstrap JavaScript file.
You could also reference the jQuery and Bootstrap library from a Content Delivery Network (CDN). This is a good approach to use when adding references to the most widely used JavaScript libraries. This should allow your site to load faster if the user has already visited a site that uses the same library from the same CDN, because the library will be cached in their browser.
In order to reference the Bootstrap and jQuery libraries from a CDN, change the <script> tags to the following:
You can download the example code files for this book from https://github.com/Pietervdw/bootstrap-for-aspnetmvc.
There are a number of CDNs available on the Internet; listed here are some of the more popular options:
source : https://subscription.packtpub.com/book/web_development/9781785889479/1/ch01lvl1sec14/creating-a-mvc-layout-page

Friday, August 2, 2019

Multiple Models in Single View in MVC

Introduction


In MVC we cannot pass multiple models from a controller to the single view. This article provides a workaround for multiple models in a single view in MVC.

Problem Statement


Suppose I have two models, Teacher and Student, and I need to display a list of teachers and students within a single view. How can we do this?

The following are the model definitions for the Teacher and Student classes.
  1. public class Teacher  
  2. {  
  3.     public int TeacherId { get; set; }  
  4.     public string Code { get; set; }  
  5.     public string Name { get; set; }  
  6. }   
  7.   
  8. public class Student  
  9. {  
  10.     public int StudentId { get; set; }  
  11.     public string Code { get; set; }  
  12.     public string Name { get; set; }  
  13.     public string EnrollmentNo { get; set; }  
  14. }  
The following are the methods that help us to get all the teachers and students.
  1. private List<Teacher> GetTeachers()  
  2. {  
  3.     List<Teacher> teachers = new List<Teacher>();  
  4.     teachers.Add(new Teacher { TeacherId = 1, Code = "TT", Name = "Tejas Trivedi" });  
  5.     teachers.Add(new Teacher { TeacherId = 2, Code = "JT", Name = "Jignesh Trivedi" });  
  6.     teachers.Add(new Teacher { TeacherId = 3, Code = "RT", Name = "Rakesh Trivedi" });  
  7.     return teachers;  
  8. }   
  9.   
  10. public List<Student> GetStudents()  
  11. {  
  12.     List<Student> students = new List<Student>();  
  13.     students.Add(new Student { StudentId = 1, Code = "L0001", Name = "Amit Gupta", EnrollmentNo = "201404150001" });  
  14.     students.Add(new Student { StudentId = 2, Code = "L0002", Name = "Chetan Gujjar", EnrollmentNo = "201404150002" });  
  15.     students.Add(new Student { StudentId = 3, Code = "L0003", Name = "Bhavin Patel", EnrollmentNo = "201404150003" });  
  16.     return students;  
  17. }  
Required output
output

Solution
 
There are many ways to use multiple models with a single view. Here I will explain ways one by one.


1. Using Dynamic Model

ExpandoObject (the System.Dynamic namespace) is a class that was added to the .Net Framework 4.0 that allows us to dynamically add and remove properties onto an object at runtime. Using this ExpandoObject, we can create a new object and can add our list of teachers and students into it as a property. We can pass this dynamically created object to the view and render list of the teacher and student.

Controller Code
  1. public class HomeController : Controller  
  2. {  
  3.     public ActionResult Index()  
  4.     {  
  5.         ViewBag.Message = "Welcome to my demo!";  
  6.         dynamic mymodel = new ExpandoObject();  
  7.         mymodel.Teachers = GetTeachers();  
  8.         mymodel.Students = GetStudents();  
  9.         return View(mymodel);  
  10.     }  
  11. }  
We can define our model as dynamic (not a strongly typed model) using the @model dynamic keyword.
View Code
  1. @using MultipleModelInOneView;  
  2. @model dynamic  
  3. @{  
  4.     ViewBag.Title = "Home Page";  
  5. }  
  6. <h2>@ViewBag.Message</h2>  
  7.    
  8. <p><b>Teacher List</b></p>  
  9.    
  10. <table>  
  11.     <tr>  
  12.         <th>Id</th>  
  13.         <th>Code</th>  
  14.         <th>Name</th>  
  15.     </tr>  
  16.     @foreach (Teacher teacher in Model.Teachers)  
  17.     {  
  18.         <tr>  
  19.             <td>@teacher.TeacherId</td>  
  20.             <td>@teacher.Code</td>  
  21.             <td>@teacher.Name</td>  
  22.         </tr>  
  23.     }  
  24. </table>  
  25.    
  26. <p><b>Student List</b></p>  
  27.    
  28. <table>  
  29.     <tr>  
  30.         <th>Id</th>  
  31.         <th>Code</th>  
  32.         <th>Name</th>  
  33.         <th>Enrollment No</th>  
  34.     </tr>  
  35.     @foreach (Student student in Model.Students)  
  36.     {  
  37.         <tr>  
  38.             <td>@student.StudentId</td>  
  39.             <td>@student.Code</td>  
  40.             <td>@student.Name</td>  
  41.             <td>@student.EnrollmentNo</td>  
  42.         </tr>  
  43.     }  
  44. </table>  

2. Using View Model


ViewModel is nothing but a single class that may have multiple models. It contains multiple models as a property. It should not contain any method.

In the above example, we have the required View model with two properties. This ViewModel is passed to the view as a model. To get intellisense in the view, we need to define a strongly typed view.
  1. public class ViewModel  
  2. {  
  3.     public IEnumerable<Teacher> Teachers { get; set; }  
  4.     public IEnumerable<Student> Students { get; set; }  
  5. }  
Controller code
  1. public ActionResult IndexViewModel()  
  2. {  
  3.     ViewBag.Message = "Welcome to my demo!";  
  4.     ViewModel mymodel = new ViewModel();  
  5.     mymodel.Teachers = GetTeachers();  
  6.     mymodel.Students = GetStudents();  
  7.     return View(mymodel);  
  8. }  
View code
  1. @using MultipleModelInOneView;  
  2. @model ViewModel   
  3. @{  
  4.     ViewBag.Title = "Home Page";  
  5. }  
  6. <h2>@ViewBag.Message</h2>  
  7.    
  8. <p><b>Teacher List</b></p>  
  9.    
  10. <table>  
  11.     <tr>  
  12.         <th>Id</th>  
  13.         <th>Code</th>  
  14.         <th>Name</th>  
  15.     </tr>  
  16.     @foreach (Teacher teacher in Model.Teachers)  
  17.     {  
  18.         <tr>  
  19.             <td>@teacher.TeacherId</td>  
  20.             <td>@teacher.Code</td>  
  21.             <td>@teacher.Name</td>  
  22.         </tr>  
  23.     }  
  24. </table>  
  25.    
  26. <p><b>Student List</b></p>  
  27.    
  28. <table>  
  29.     <tr>  
  30.         <th>Id</th>  
  31.         <th>Code</th>  
  32.         <th>Name</th>  
  33.         <th>Enrollment No</th>  
  34.     </tr>  
  35.     @foreach (Student student in Model.Students)  
  36.     {  
  37.         <tr>  
  38.             <td>@student.StudentId</td>  
  39.             <td>@student.Code</td>  
  40.             <td>@student.Name</td>  
  41.             <td>@student.EnrollmentNo</td>  
  42.         </tr>  
  43.     }  
  44. </table>  

3. Using ViewData


ViewData is used to transfer data from the controller to the view. ViewData is a dictionary object that may be accessible using a string as the key. Using ViewData, we can pass any object from the controller to the view. The Type Conversion code is required when enumerating in the view.
 
For the preceding example, we need to create ViewData to pass a list of teachers and students from the controller to the view.

Controller Code
  1. public ActionResult IndexViewData()  
  2. {  
  3.     ViewBag.Message = "Welcome to my demo!";  
  4.     ViewData["Teachers"] = GetTeachers();  
  5.     ViewData["Students"] = GetStudents();  
  6.     return View();  
  7. }  
View Code
  1. @using MultipleModelInOneView;  
  2. @{  
  3.     ViewBag.Title = "Home Page";  
  4. }  
  5. <h2>@ViewBag.Message</h2>  
  6.  <p><b>Teacher List</b></p>   
  7. @{  
  8.   
  9.    IEnumerable<Teacher> teachers = ViewData["Teachers"] as IEnumerable<Teacher>;  
  10.    IEnumerable<Student> students = ViewData["Students"] as IEnumerable<Student>;  
  11. }  
  12. <table>  
  13.     <tr>  
  14.         <th>Id</th>  
  15.         <th>Code</th>  
  16.         <th>Name</th>  
  17.     </tr>  
  18.     @foreach (Teacher teacher in teachers)  
  19.     {  
  20.         <tr>  
  21.             <td>@teacher.TeacherId</td>  
  22.             <td>@teacher.Code</td>  
  23.             <td>@teacher.Name</td>  
  24.         </tr>  
  25.     }  
  26. </table>  
  27.  <p><b>Student List</b></p>  
  28. <table>  
  29.     <tr>  
  30.         <th>Id</th>  
  31.         <th>Code</th>  
  32.         <th>Name</th>  
  33.         <th>Enrollment No</th>  
  34.     </tr>  
  35.     @foreach (Student student in students)  
  36.     {  
  37.         <tr>  
  38.             <td>@student.StudentId</td>  
  39.             <td>@student.Code</td>  
  40.             <td>@student.Name</td>  
  41.             <td>@student.EnrollmentNo</td>  
  42.         </tr>  
  43.     }  
  44. </table>  

4. Using ViewBag


ViewBag is similar to ViewData and is also used to transfer data from the controller to the view. ViewBag is a dynamic property. ViewBag is just a wrapper around the ViewData.

Controller Code 
  1. public ActionResult IndexViewBag()  
  2. {  
  3.     ViewBag.Message = "Welcome to my demo!";  
  4.     ViewBag.Teachers = GetTeachers();  
  5.     ViewBag.Students = GetStudents();  
  6.     return View();  
  7. }  
View Code
  1. @using MultipleModelInOneView;  
  2. @{  
  3.     ViewBag.Title = "Home Page";  
  4. }  
  5. <h2>@ViewBag.Message</h2>  
  6.    
  7. <p><b>Teacher List</b></p>  
  8.    
  9. <table>  
  10.     <tr>  
  11.         <th>Id</th>  
  12.         <th>Code</th>  
  13.         <th>Name</th>  
  14.     </tr>  
  15.     @foreach (Teacher teacher in ViewBag.Teachers)  
  16.     {  
  17.         <tr>  
  18.             <td>@teacher.TeacherId</td>  
  19.             <td>@teacher.Code</td>  
  20.             <td>@teacher.Name</td>  
  21.         </tr>  
  22.     }  
  23. </table>  
  24.    
  25. <p><b>Student List</b></p>  
  26.    
  27. <table>  
  28.     <tr>  
  29.         <th>Id</th>  
  30.         <th>Code</th>  
  31.         <th>Name</th>  
  32.         <th>Enrollment No</th>  
  33.     </tr>  
  34.     @foreach (Student student in ViewBag.Students)  
  35.     {  
  36.         <tr>  
  37.             <td>@student.StudentId</td>  
  38.             <td>@student.Code</td>  
  39.             <td>@student.Name</td>  
  40.             <td>@student.EnrollmentNo</td>  
  41.         </tr>  
  42.     }  
  43. </table>  

5. Using Tuple


A Tuple object is an immutable, fixed-size and ordered sequence object. It is a data structure that has a specific number and sequence of elements. The .NET framework supports tuples up to seven elements.

Using this tuple object we can pass multiple models from the controller to the view.

Controller Code
  1. public ActionResult IndexTuple()  
  2. {  
  3.     ViewBag.Message = "Welcome to my demo!";  
  4.     var tupleModel = new Tuple<List<Teacher>, List<Student>>(GetTeachers(), GetStudents());  
  5.     return View(tupleModel);  
  6. }  
View Code
  1. @using MultipleModelInOneView;  
  2. @model Tuple <List<Teacher>, List <Student>>  
  3. @{  
  4.     ViewBag.Title = "Home Page";  
  5. }  
  6. <h2>@ViewBag.Message</h2>   
  7. <p><b>Teacher List</b></p>  
  8. <table>  
  9.     <tr>  
  10.         <th>Id</th>  
  11.         <th>Code</th>  
  12.         <th>Name</th>  
  13.     </tr>  
  14.     @foreach (Teacher teacher in Model.Item1)  
  15.     {  
  16.         <tr>  
  17.             <td>@teacher.TeacherId</td>  
  18.             <td>@teacher.Code</td>  
  19.             <td>@teacher.Name</td>  
  20.         </tr>  
  21.     }  
  22. </table>  
  23. <p><b>Student List</b></p>  
  24. <table>  
  25.     <tr>  
  26.         <th>Id</th>  
  27.         <th>Code</th>  
  28.         <th>Name</th>  
  29.         <th>Enrollment No</th>  
  30.     </tr>  
  31.     @foreach (Student student in Model.Item2)  
  32.     {  
  33.         <tr>  
  34.             <td>@student.StudentId</td>  
  35.             <td>@student.Code</td>  
  36.             <td>@student.Name</td>  
  37.             <td>@student.EnrollmentNo</td>  
  38.         </tr>  
  39.     }  
  40. </table>  

6. Using Render Action Method


A Partial View defines or renders a partial view within a view. We can render some part of a view by calling a controller action method using the Html.RenderAction method. The RenderAction method is very useful when we want to display data in the partial view. The disadvantages of this method is that there are only multiple calls of the controller.

In the following example, I have created a view (named partialView.cshtml) and within this view I called the html.RenderAction method to render the teacher and student list.

Controller Code
  1. public ActionResult PartialView()  
  2. {  
  3.     ViewBag.Message = "Welcome to my demo!";  
  4.     return View();  
  5. }  
  6.    
  7. /// <summary>  
  8. /// Render Teacher List  
  9. /// </summary>  
  10. /// <returns></returns>  
  11. public PartialViewResult RenderTeacher()  
  12. {  
  13.     return PartialView(GetTeachers());  
  14. }  
  15.    
  16. /// <summary>  
  17. /// Render Student List  
  18. /// </summary>  
  19. /// <returns></returns>  
  20. public PartialViewResult RenderStudent()  
  21. {  
  22.     return PartialView(GetStudents());  
  23. }  
View Code
  1. @{  
  2.    ViewBag.Title = "PartialView";  
  3. <h2>@ViewBag.Message</h2>  
  4. <div>  
  5.     @{  
  6.         Html.RenderAction("RenderTeacher");  
  7.         Html.RenderAction("RenderStudent");  
  8.     }  
  9. </div>  
RenderTeacher.cshtml
  1. @using MultipleModelInOneView;  
  2. @model IEnumerable<MultipleModelInOneView.Teacher>  
  3.  <p><b>Teacher List</b></p>  
  4. <table>  
  5.     <tr>  
  6.         <th>Id</th>  
  7.         <th>Code</th>  
  8.         <th>Name</th>  
  9.     </tr>  
  10.     @foreach (Teacher teacher in Model)  
  11.     {  
  12.         <tr>  
  13.             <td>@teacher.TeacherId</td>  
  14.             <td>@teacher.Code</td>  
  15.             <td>@teacher.Name</td>  
  16.         </tr>  
  17.     }  
  18. </table>  
RenderStudent.cshtml
  1. @using MultipleModelInOneView;  
  2. @model IEnumerable<MultipleModelInOneView.Student>   
  3.   
  4. <p><b>Student List</b></p>  
  5. <table>  
  6.     <tr>  
  7.         <th>Id</th>  
  8.         <th>Code</th>  
  9.         <th>Name</th>  
  10.         <th>Enrollment No</th>  
  11.     </tr>  
  12.     @foreach (Student student in Model)  
  13.     {  
  14.         <tr>  
  15.             <td>@student.StudentId</td>  
  16.             <td>@student.Code</td>  
  17.             <td>@student.Name</td>  
  18.             <td>@student.EnrollmentNo</td>  
  19.         </tr>  
  20.     }  
  21. </table>  

Conclusion


This article helps us to learn how to pass multiple models from the controller to the view. I hope this will be helpful for beginners.

source  : https://www.c-sharpcorner.com/UploadFile/ff2f08/multiple-models-in-single-view-in-mvc/