data:image/s3,"s3://crabby-images/0ebe3/0ebe35938eba90bfd83594ee7c5ac13c656dc9a8" alt="clock"
January 12, 2012 07:24 by
Scott
Step 1:
Create a new ASP.Net MVC 3 application with an empty web application. While creating the project check the radio button "UnitTest".
Step 2:
Now under the "Model" folder create two classes.
1. Blog
2. Comments
data:image/s3,"s3://crabby-images/28594/28594b552f78081a7c7c21d4d9f39d200b24b704" alt="image_1"
Step 3:
Now In the Blog Class Copy the following code:
public class Blog
{
[Key]
public int BlogId { get; set; }
[Required(ErrorMessage = "BlogName is required")]
public string BlogName { get; set; }
[Required(ErrorMessage = "Description is required")]
[StringLength(120, ErrorMessage = "Description Name Not exceed more than 120 words")]
public string Description { get; set; }
public string Body { get; set; }
public virtual List<Comments > Comments_List { get; set; }
}
See here is the validation of each property. And also hold the list of comments. That means 1 blog contains many posts. So that is a one to many relationship.
The "Virtual" keywords means it will make the relationship.
Step 4:
Now in the Comments class write the following code:
public class Comments
{
[Key ]
public int CommentId { get; set; }
public string Comment { get; set; }
//[ForeignKey]
public int BlogId { get; set; }
public virtual Blog Blog { get; set; }
}
See here we also have the object reference of the "blog" class. Before that I have used the virtual key word.
Step 5:
Now it's time to make the entity class by which the database and the table will create.
Create a "DatabaseContext" folder under the project. After that create a class named "BlogDbContext.cs" under the folder. This class is an entity class.
Step 6:
Now make a reference for the Entity Framework by clicking "Add Reference" under the project.
data:image/s3,"s3://crabby-images/7626a/7626ab71dedad652ffa41f36ed30475c5bf77330" alt="image_2"
In my project I had already provided the dll. Without this dll the table cannot be created in the database by object class mapping.
Now paste the following code into the "BlogDbContext" class:
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Data.Entity;
using blogmvc3.Models;
namespace blogmvc3.DatabaseContext
{
public class BlogDbContext:DbContext
{
public DbSet<Blog> Blog { get; set; }
public DbSet<Comments> Comments { get; set; }
}
}
See here in the Dbset we are passing a blog class and a comments class. The Dbset will create a table automatically with a relation in the database.
The Namespace "System.Data.Entity" is very important for that.
Step 7:
Now we have to configure the "web.config" file for the connection string. The web.config file is under the Main Solution Project. Not the Project web.config file.
data:image/s3,"s3://crabby-images/01fb5/01fb502858fdd070b746e19d1d0d8d099d7e5ee9" alt="image_3"
Now paste the following connection string into the web.config file.
data:image/s3,"s3://crabby-images/30ddf/30ddf564d92239da25f3b169b0b358ba7bffe2ca" alt="image_4"
Step 8:
Now create a Controller Class named "HomeController" under the "ControllerFolder. After that check the "Add action for create.update,delete.." so it will automatically create the action mrthod in the Controller class.
data:image/s3,"s3://crabby-images/7523e/7523e81d7b845232296a595ea34f1e6cfce6e8b4" alt="image_5"
data:image/s3,"s3://crabby-images/54ef3/54ef3cc5be5b7b3055906daf4260fda674de828f" alt="image_6"
Step 9:
Now in the "HomeController" Class first create an object of the "BlogDbContext" Class .
BlogDbContext _db = new BlogDbContext();
After that in the Index Method write the following code:
public ActionResult Index()
{
return View(_db.Comments .ToList ());
}
Step 10:
Now create a master page in the Razor engine under the "shared" folder. Give it the name "_LayoutPage1.cshtml".
data:image/s3,"s3://crabby-images/5681b/5681b81953d98cf69bd61f1a096d71caae4d974f" alt="image_7"
After that paste the following code there:
<!DOCTYPE html>
<html>
<head>
<title>@ViewBag.Title</title>
<link href="@Url.Content("~/Content/Site.css")" rel="stylesheet" type="text/css" />
<script src="@Url.Content("~/Scripts/jquery-1.4.4.min.js")" type="text/javascript"></script>
@* <script src="../../Scripts/jquery-ui-1.8.11.custom.min.js" type="text/javascript"></script>
<link href="../../Content/jquery-ui-1.8.11.custom.css" rel="stylesheet" type="text/css" />*@
</head>
<body>
<div class="page">
<div id="header">
<div id="title">
<h1>Blog Post</h1>
</div>
<div id="logindisplay">
@*@Html.Partial("_LogOnPartial")*@
</div>
<div id="menucontainer">
<ul id="menu">
@* <li>@html.actionlink("home", "index", "home")</li>*@
@*<li>@Html.ActionLink("About", "About", "Home")</li>*@
<li>@Html.ActionLink("home", "index", "home")</li>
<li>@Html.ActionLink("Article Post", "CreateLogin", "Article")</li>
@*<li>@Html.ActionLink("BookCab", "CreateLogin", "Cab")</li> *@
</ul>
</div>
<script type="text/javascript"><!-- mce: 0--></script>
</div>
<div id="main">
@RenderBody()
<div id="footer">
</div>
</div>
</div>
</body>
</html>
Step 11:
Now go the "Home controller". Right-click the Index Method and add a view. It will look like:
data:image/s3,"s3://crabby-images/69596/695964575a6f3210a599ce8aad4e7330f00cd348" alt="image_8"
Please check "Create Strongly-typed Views".
Choose Model Class "Comments" Under DropDown List.
Select "Scaffold Template" List. After that press the "Add" button. It will automatically create a view named "Index" under the "Home" folder.
Step 12:
See the Index View Engine will create code for the list view automatically.
Now delete all the code and replace it with the following code:
@model IEnumerable<blogmvc3.Models.Comments>
@{
ViewBag.Title = "Index";
Layout = "~/Views/Shared/_LayoutPage1.cshtml";
}
@{
var grid = new WebGrid(source: Model, canPage: true, defaultSort: "BlogName", rowsPerPage: 3, canSort: true);
}
<h2>Web grid</h2>
if (@Model != null )
{
@grid.GetHtml(tableStyle:"grid",headerStyle: "head", alternatingRowStyle: "alt",caption:"WebGrid"
)
}
<p>
@Html.ActionLink("Create New", "Create")
</p>
Now see this code section what is written above.
data:image/s3,"s3://crabby-images/6eb78/6eb780f6c56e89491fcd52548da2324c9d2a0407" alt="image_9"
See first we are creating the WebGrid and after that in the constructor parameter we are passing a different property argument such as paging property, sorting, and rows per page.
And in the second we are are calling the WebGrid by calling the "@Html.WebGrid" property. Here also we are passing a parameter for the WebGrid.
Now run the application; it will look like the following figure:
data:image/s3,"s3://crabby-images/6c488/6c4888ff34f2efc2ce759e790e3d4b26cae4d619" alt="image_10"
See here the BlogId and Comments are displaying in the WebGrid (marked with red). And the paging facility is also done (marked with black).