Click here to Skip to main content
Click here to Skip to main content

Learning MVC - Part 1: Introduction to MVC Architecture and Separation of Concerns

, 6 Dec 2013
Rate this:
Please Sign up or sign in to vote.
Introduction to MVC architecture and Separation of Concerns.

Introduction 

 

After having gone through numerous of blogs and articles, I came to a conclusion that very few of the genuine writers have explained the topic from the basic to full-fledged, while including a working application. My effort in this MVC articles series will be to cover almost all the aspects of MVC starting from creating a simple app and connecting with the database with various Microsoft providers. We’ll be gradually moving forward part by part so we can understand and practically implement every scenario.

Road Map

 

All set? Let's start our journey with Part1.  

Part1: Introduction to MVC architecture and Separation of Concerns

Topics to be Covered

  1. What does MVC mean.
  2. Understanding MVC Architecture.
  3. Separation of Concerns

Players

Model: The business entity on which the overall application operates. Many applications use a persistent storage mechanism (such as a database) to store data. MVC does not specifically mention the data access layer because it is understood to be encapsulated by the Model.

View: The user interface that renders the model into a form of interaction.

Controller: Handles a request from a view and updates the model that results a change in Model’s state.

To implement MVC in .NET we need mainly three classes (View, Controller and the Model).

MVC Architecture

           The choice of MVC comes when we go for a solution where the separation of concerns, ease of maintainability and extensibility of an application matters a lot. As per the architecture given below, we can see the request-response flow of a MVC application.

The architecture is self explanatory. The browser (as usual) sends a request to IIS, IIS searches for the route defined in MVC application and passes the request to the controller as per route, the controller communicates with the model and passes the populated model (entity) to View (front end), Views are populated with model properties, and are rendered on the browser, passing the response to browser through IIS via controllers which invoked the particular View.

Separation of Concern

As per Wikipedia 'the process of breaking a computer program into distinct features that overlap in functionality as little as possible'. MVC design pattern aims to separate content from presentation and data-processing from content. Theoretically sound, but where do we see this in MVC? One place is reasonably clear - between the data-processing (Model) and the rest of the application.

When we talk about Views and Controllers, their ownership itself explains separation. The views are just the presentation form of an application, it does not have to know specifically about the requests coming from controller. The Model is independent of View and Controllers, it only holds business entities that can be passed to any View by the controller as required for exposing them to the end user. The controller is independent of Views and Models, its sole purpose is to handle requests and pass it on as per the routes defined and as per the need of rendering views. Thus our business entities (model), business logic (controllers) and presentation logic (views) lie in logical/physical layers independent of each other.

Conclusion

Now that we know why and where to use MVC, in the next part of the series we’ll be creating an MVC application from scratch, and exploring the practical implementation of MVC. For more informative articles,visit my blog A Practical Approach 

Learn  Code First Approach using Entity Framework 4.1, Inversion of Control, Unity Framework, Repository & Unit of Work Pattern and MVC3 Razor View  , a complete end to end solution. 

 

 

 

License

This article, along with any associated source code and files, is licensed under The Code Project Open License (CPOL)

About the Author

Akhil Mittal
Technical Lead
India India
I am a C# Corner MVP,a Code project MVP,author,blogger and currently working as an Analyst in an MNC and have an experience of more than 7 years in C#.Net. I am a B.Tech in Computer Science and hold a diploma in Information Security and Application Development. My work experience includes Development of Enterprise Applications using C#,.Net and Sql Server,Analysis as well as Research and Development. I am a MCP in Web Applications(MCTS-70-528,MCTS-70-515) and .Net Framework 2.0 (MCTS-70-536). Please visit my blog A Practical Approach for more informative articles.
____________________________________________________________________________________________________________________
 
Article of the Day on Microsoft's site http://www.asp.net/community/articles on 16 August 2013.
Article of the Day on Microsoft's site http://www.asp.net/community/articles on 28 August 2013.
Article of the Day on Microsoft's site http://www.asp.net/community/articles on 08 Sept 2013.
Article of the Day on Microsoft's site http://www.asp.net/community/articles on 29 Sept 2013.
Article of the Day on Microsoft's site http://www.asp.net/community/articles on 29 Oct 2013.
Article of the Day on Microsoft's site http://www.asp.net/community/articles on 21 May 2014.
Article of the Day on Microsoft's site http://www.asp.net/community/articles on 19 July 2014.
Member of the month for July 2013 on C# Corner
Month Winner for July 2013 on C# Corner
http://www.c-sharpcorner.com/News/3067/july-2013-month-winners-announced.aspx
Month Winner for May 2014 on C# Corner
http://www.c-sharpcorner.com/News/3798/may-2014-month-winners-announced.aspx
Group type: Collaborative Group

153 members

Follow on   Twitter   Google+   LinkedIn

Comments and Discussions

 
GeneralMy vote of 1 PinpremiumSyed M Hussain30-Jun-14 2:14 
GeneralMy vote of 1 PinmemberMember 1001700228-May-14 21:18 
GeneralMy vote of 1 Pinmemberdeba prasad satapathy22-Apr-14 22:42 
GeneralRe: My vote of 1 PinmvpAkhil_Mittal22-Apr-14 22:44 
GeneralMy vote of 2 Pinmember_Gandalf - The White_18-Feb-14 20:43 
GeneralRe: My vote of 2 PinmvpAkhil_Mittal19-Feb-14 5:00 
GeneralRe: My vote of 2 Pinmember_Gandalf - The White_19-Feb-14 19:15 
GeneralMy vote of 2 Pinmember_Psychopomp_10-Sep-13 5:46 
GeneralRe: My vote of 2 PingroupAkhil_Mittal10-Sep-13 17:46 
GeneralMy vote of 2 PinmemberBillWoodruff10-Sep-13 3:11 
GeneralRe: My vote of 2 PingroupAkhil_Mittal10-Sep-13 17:45 
GeneralMy vote of 5 PinmemberVitorHugoGarcia9-Sep-13 22:13 
GeneralRe: My vote of 5 PingroupAkhil_Mittal9-Sep-13 22:48 
QuestionThis sould not be an article PinprotectorPete O'Hanlon9-Sep-13 2:28 
AnswerRe: This sould not be an article PingroupAkhil_Mittal9-Sep-13 3:42 
GeneralRe: This sould not be an article PinprotectorPete O'Hanlon9-Sep-13 3:50 
SuggestionRe: This sould not be an article PinpremiumKornfeld Eliyahu Peter30-Apr-14 0:07 
GeneralArticle of the day on Microsoft's Asp.net Site PingroupAkhil_Mittal27-Aug-13 19:54 
GeneralMy vote of 5 PinprofessionalMenon Santosh22-Aug-13 20:40 
GeneralRe: My vote of 5 PingroupAkhil_Mittal22-Aug-13 22:45 
GeneralRe: My vote of 5 PinprofessionalMenon Santosh23-Aug-13 3:24 
GeneralMy Vote of 5 Pinmembersridharsh16-Aug-13 4:39 
GeneralMy vote of 5 PinmemberChris Dis15-Aug-13 22:46 
GeneralRe: My vote of 5 PingroupAkhil_Mittal15-Aug-13 22:47 
GeneralMy vote of 5 Pinmembergarg prachi15-Aug-13 4:15 

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

| Advertise | Privacy | Mobile
Web02 | 2.8.140721.1 | Last Updated 7 Dec 2013
Article Copyright 2013 by Akhil Mittal
Everything else Copyright © CodeProject, 1999-2014
Terms of Service
Layout: fixed | fluid