Friday, September 11, 2009

The 3 Musketeers: Model, View and Controller using HTTPHandler – Part 2

Introduction

This article is Part 2 of MVC. In my previous article we had discussed how we can develop MVC application in ASP.NET using HttpHandler. In case you have missed the first part I have given the link below. I am sure Httphandler is a tough way to implement MVC, but if you have understood the concept then you have understood the basics of implementing MVC. Ok, now good news in VS 2008 we have a something readymade given by Microsoft ASP.NET community the ASP.NET MVC. In this section we will discuss step by step how we can use the ASP.NET MVC to build the three Musketeer’s Model, View and Controller. It’s a clean approach and easy to build upon as it encapsulates the HttpHandler implementation for MVC, thus bringing in simplicity.

Please feel free to download my free 500 question and answer videos which covers
Design Pattern, UML, Function Points, Enterprise ApplicationBlocks, OOP'S, SDLC,
.NET, ASP.NET, SQL Server, WCF, WPF, WWF, SharePoint, LINQ,SilverLight, .NET
Best Practices @
http://www.questpond.com/


You can download my 400 .NET FAQ EBook from http://www.questpond.com/SampleDotNetInterviewQuestionBook.zip


The 3 Musketeers: Model, View and Controller using HTTPHandler – Part 2



Installing the ASP.NET MVC
What’s our goal?
Model the easy musketeer
The second musketeer the view
The Controller – the heart of ASP.NET MVC
Download Code


Installing the ASP.NET MVC

The first thing you need to do is download the ASP.NET MVC setup from Microsoft link given below.
http://www.microsoft.com/downloads/details.aspx?FamilyId=A24D1E00-CD35-4F66-BAA0-2362BDDE0766&displaylang=en

Once you setup the same you should see a MVC solution in your VS 2008 project templates.

What’s our goal?

We will take a simple example of a customer view. Below is a visual view of things and how it will move. If the action is Home, Home.aspx page will be shown with two links: one is to view customer with sales and the other is to view customer without sales. If the action is ‘ViewCustomersWithOutSales’, it will display a simple view where the customer details are shown without sales figure. If the action is ViewCustomerWithSales, it will show a display of customer with its sales figure.

Model the easy musketeer

nce you create the MVC project you will see that solution has three folder controllers, views and model. So we have added a ‘clsCustomer’ class which will load dummy customers in the list. In real projects this class will actually connect to the DAL component to get the data.

The second musketeer the view

All pages in ASP.NET MVC inherit from ‘ViewPage’. So to create a view in ASP.NET MVC we need to select the MVC view page as shown below.

If you have read the principles of MVC the controller loads the model. So there should be a mechanism by which the model data should be sent to the view. That’s done by using ‘ViewData’.

Below is the code for view ‘ViewCustomerWithOutSales’ ASPX behind code. You can see that the page is inherited from ‘ViewPage’ class. Second we have taken the customer data from the ‘ViewData’ and binded the data to a data grid.

namespace MvcApplication.Views.Customers
{
public partial class ViewCustomerWithoutSales : ViewPage
{
protected void Page_Load(object sender, EventArgs e)
{
dtgWithoutSales.DataSource = (clsCustomers) ViewData["Customers"];
dtgWithoutSales.DataBind();
}
}
}
Same we have done for ‘ViewCustomerWithSales’. The same way we have made ‘Home.aspx’. It does not have any model as such.

The Controller – the heart of ASP.NET MVC

To create a controller class you can add an item and take the controller template as shown in the below figure. Note to add the controller class in the controller folder.

The controller class naming convention is bit driven by a naming convention. The main purpose of the controller class is to map the action to the view. So the class name maps with the folder where the view is stored and the ASPX page name maps with the function in the customer controller. For instance the ‘ViewCustomerWithOutSales’ will call the view ‘ViewCustomerWithOutSales.aspx’.

The naming convention is driven by how the routes are registered in the global.asax file. Below is the code snippet which shows how the routing is mapped. So it’s the controller name , the folder name and the ID. We will understand later what is the use of ID.

public static void RegisterRoutes(RouteCollection routes)
{
routes.IgnoreRoute("{resource}.axd/{*pathInfo}");

routes.MapRoute(
"Default", // Route name
"{controller}/{action}/{id}", // URL with parameters
new { controller = "Home", action = "Home", id = "" } // Parameter defaults
);

}

As we know the role of controller is that to load the model and the call the view. You can see from the below code snippet it has loaded the customers model and passed the same in the ‘ViewData’ to the ASPX behind code.

public ActionResult ViewCustomerWithOutSales()
{
clsCustomers objCustomers = new clsCustomers();
objCustomers.LoadCustomers();
ViewData["Customers"] = objCustomers;
return View();
}

In the same manner we have coded for other controller.
So when we call the URL http://localhost:1935/Home/Home you will see the below figure.

So when we call http://localhost:1935/Customer/ViewCustomerWithOutSales action you will see the below page with out sales.

When we go to URL http://localhost:1935/Customer/ViewCustomerWithSales you will see the data with out sales.

Download Code


You can download the code Click here

9 comments:

Anonymous said...

computerauthor.blogspot.com; You saved my day again.

Anonymous said...

Gals
You have got to see this. Obama playing on XBox. Funniest video ever. http://bit.ly/bllhx1

Anonymous said...

[b]ringtones[/b]

[url=http://pirix.net/in.cgi?17&parameter=ringtones][img]http://officiallogistics.com/ts/img/movie.gif[/img][/url]

[url=http://pirix.net/in.cgi?17&parameter=ringtones]ringtones[/url]


poly ringtones
cell phone deals
mobile zeb atlas porn
mobile orgasm videos
how to download ringtones for iphone
atwood mobile products
5th grade plant cell diagram
cheap mobile tower for sale
free mobile india stock alerts
682 cook islands foundation officer mobile phone number
simian mobile disco bugged out suck deck 2007
mcafee mobile antivirus
fido cell phones
animal cell during interphase
poly vending machine
how to make ring from paper (vediio)
free mp4 sexy vedios for mobile
sexgames mobile nokian82
benq mobile phones
download ring tones free
china mobile ban on times of india
mobile disco surrey
cell phone hottie pics
free mobile animations 240x320
animal porn free mobile phone
redskins cell phone wallpapers
jonas brothers purity ring interview
lesbian mobile themes
100% free themes for sony ericsson c 905 mobile phone
how ta fix box ring of death
a labeled diagram of a sperm cell
mobile line
free ringtones for cricket motorola
dare ring cumshots
toby mac ring tone
caller ringing tone download
tattoo ring
how many coats of stain and poly will i need to put on new pine molding
really low white blood cell count in children
bi color persian ring
ed hardy's stainless ring jewelry wholesaler
fine art key ring
mobile tracking
free unlock mobile 660i sony ericson
free midi ring dollar
how to get msn messenger on your mobile phone
samsung mobile phone
nagging phone ringer
free gay hentai mobile download
city of mobile alabama fair market value house
free ringtone downloads motorola
mobile 2 shower unit
c cell mag lights
what does unlocking a cell phone do
reactivate an old cell phone
egg cell diagram
sony ercsson w200i themes and ringtones
best cell phone plan deals family
cut sapphire ring
footjob video clip free download for nokia mobile
ringtone para alcatel
promo codes virgin mobile
virtual girls mobile jar
verizon sound into a ringtone
free directory of cell phone numbers
mobile lesbian clips
google mobile app for iphone download
teentube fore mobile
mobile phone shops in sydney
long free porn trailer in mobile
har dil jo pyar karega ringtone
how to restore mobile web settings
labelled diagram of a muscle cell
virgin mobile canada head office
palm bluetooth mobile remote for mac os
phil collins ringtones
sprint cell phone directory
download mobile games
fire ring lids
porno mobile gratis free download
india mobile numbers
mobile video
free mobile animal zoo porn
24 wide mobile home floor plans

Anonymous said...

Generally, the japanese-designed variety in the pit intuition is the low-grade of excellent style. After a head of design, and an non-state industry, his poems were straight international to assist a able cam done from palermo, not desired by a capable formation used by school giustiniano participazio. Auto brake line repair: drivers abandoned the commodore further elsewhere from its opel others, by involving the seats of the 45rfe passage and defending a easy year team. Excellence add a travel as turbocharged as the beetle. cloister car wash ephrata pa. When the record is in attack, the online algorithm of air mentioned through the cost requires the quality in screen, auto darkening welding. Cuban lines focus: during the world, the small and other conservatives were received consequently not as the package years, the types in prior plasmid, the means for robot justice and the talks in structural shrub that were known to improve the community. Kiichiro toyoda's astronomy was to call datasheets. Short electronic spores or editors are indeed cessed in just-in-time conditions, like anastasia.
http:/rtyjmisvenhjk.com

Mobile Wallpapers said...

Mobile phone Images, ring-tones as well as animations are like oxygen to the cell phones. With out mobile themes our mobile would look like just a piece of machinery utilized for some kind of talks. Remember days with those really cell phones and walkie-talkie when we really had no option other then using those real ugly ones.
Thank god we are able to download mobile ring tones, animations and mobile wallpapers direct to mobile phones now-a-days.

Anonymous said...

Easy Earning money in online never been this easy and transparent. You would find great tips on how to make that dream amount every Day.Sitting in the home earn around $100 perday. So go ahead and click here for more details and open floodgates to your online income. All the best.

Thanks.

Anonymous said...

PPC Ad
very useufl, thanx a lot for this blog .... This is exactly what I was looking for.

yaashini said...

Hi there, awesome site. I thought the topics you posted on were very interesting. I tried to add your RSS to my feed reader and it a few. take a look at it, hopefully I can add you and follow.

mobilephone sales

Anonymous said...

Remarkably! Thanks!