Basic concept and fundamentals of ASP.NET MVC (Model View Controller) Architecture
This is basic concepts and fundamentals of ASP.NET Model View Controller (MVC) architecture workflow.
MVC (Model View Controller) Interaction with Browser
What is a Model?
What is a View?
MVC File Structure & File Naming Standards
MVC uses a standard directory structure and file naming standards which are a very important part of MVC application development.
ASP.NET MVC Execution Life Cycle
Browser Request (Step 1)
Job of Global.asax – MVC routing (Step 2)
Controller and Action methods (Step 3)
Call to View (Step 4)
MVC is stands for MODEL VIEW CONTROLLER. ASP.NET MVC is an architecture to develop ASP.NET web applications in a different manner than the traditional ASP.NET web development. Web applications developed with ASP.NET MVC are even more SEO (Search Engine) friendly.
Microsoft .Net Framework 3.5 is minimum requirement to develop ASP.net MVC application.
MVC (Model View Controller) Interaction with Browser
Like a normal web server interaction, MVC application also accepts requests and responds to the web browser in the same way.
Inside MVC Architecture
The entire ASP.NET MVC architecture is based on Microsoft .NET Framework 3.5 and in addition uses LINQ to SQL Server.
What is a Model?
- MVC model is basically a C# or VB.NET class
- A model is accessible by both controller and view
- A model can be used to pass data from Controller to view
- A view can use model to display data in page.
What is a View?
- View is an ASPX page without having a code behind file
- All page specific HTML generation and formatting can be done inside view
- One can use Inline code (server tags ) to develop dynamic pages
- A request to view (ASPX page) can be made only from a controller’s action method
What is a Controller?
- Controller is basically a C# or VB.NET class which inherits system.mvc.controller
- Controller is a heart of the entire MVC architecture
- Inside Controller’s class action methods can be implemented which are responsible for responding to browser OR calling views.
- Controller can access and use model class to pass data to views
- Controller uses ViewData to pass any data to view
MVC File Structure & File Naming Standards
MVC uses a standard directory structure and file naming standards which are a very important part of MVC application development.
Inside the ROOT directory of the application, there must be 3 directories each for model, view and Controller.
Apart from 3 directories, there must have a Global.asax file in root folder, and a web.config like a traditional ASP.NET application.
- Root [directory]
- Controller [directory]
- Controller CS files
- Models [directory]
- Model CS files
- Views [directory]
- View CS files
- Global.asax
- Web.config
ASP.NET MVC Execution Life Cycle
Here is how MVC architecture executes the requests to browser and objects interactions with each other.
A step by step process is explained below [Refer to the figure as given below]:
Browser Request (Step 1)
Browser request happens with a specific URL. Let’s assume that the user enters URL like: [xyz.com]/home/index/
Job of Global.asax – MVC routing (Step 2)
The specified URL will first get parsed via
application_start()
method inside Global.asax file. From the requested URL, it will parse the Controller, Action and ID.So for [xyz.com]/home/index/:
- Controller = home
- Action = index()
- ID = empty — we have not specified ID in [xyz.com]/home/index/, so it will consider as empty string
Controller and Action methods (Step 3)
MVC now finds the home controller class in controller directory. A controller class contains different action methods,
There can be more than one action method, but MVC will only invoke the action method which has been parsed from the URL, its
index()
in our case.So something like:
homeController.index()
will happen inside MVC controller class.Invoking action method can return plain text string OR rendered HTML by using view.
Call to View (Step 4)
Invoking view will return
In our case, controller was home and action was view()
. A call to view will access the particular ASPX page inside the view directory and generate the rendered HTML from the ASPX and will respond back to the browser.index()
. So calling view()
will return a rendered HTML from the ASPX page located at/views/home/index.aspx.
Comments
ASP.Net MVC Training
Online MVC Training
Online MVC Training from India
MVC Training in Chennai
C# Training
Dot Net Training in Chennai
Dot Net Training institutes in Chennai
ASP.NET Training
Regards,
dot net training in chennai | dot net course
dot net training institute in velachery
Dot Net Training in Chennai | Big Data Analytics Training in Chennai
A very interesting case study
Informatica Training In Chennai | Hadoop Training In Chennai | Sap MM Training In Chennai
Best Java Training Institute Chennai
Devops Training in Chennai
Dot Net Training in Chennai
Dot Net Course in Chennai
Good discussion.
Six Sigma Training in Abu Dhabi
Six Sigma Training in Dammam
Six Sigma Training in Riyadh
python course in pune | python course in chennai | python course in Bangalore
Java interview questions and answers
Java training in Chennai | Java training institute in Chennai | Java course in Chennai
Java training in Bangalore | Java training institute in Bangalore | Java course in Bangalore
Java interview questions and answers
Greetings. I know this is somewhat off-topic, but I was wondering if you knew where I could get a captcha plugin for my comment form? I’m using the same blog platform like yours, and I’m having difficulty finding one? Thanks a lot.
AWS Interview Questions And Answers
AWS Tutorial |Learn Amazon Web Services Tutorials |AWS Tutorial For Beginners
AWS Online Training | Online AWS Certification Course - Gangboard
AWS Training in Toronto| Amazon Web Services Training in Toronto, Canada
Data Science training in rajaji nagar | Data Science Training in Bangalore
Data Science with Python training in chennai
Data Science training in electronic city
Data Science training in USA
Data science training in pune
angularjs Training in bangalore
angularjs Training in bangalore
angularjs online Training
angularjs Training in marathahalli
angularjs interview questions and answers
It looks like you spend a lot of effort and time on your blog.
I have bookmarked it and I am looking forward to reading new articles.Keep up the good work..
PHP Training in Chennai
Selenium Training in Chennai
Digital Marketing Course in Chennai
JAVA Training in Chennai
Java training institute in chennai
Am very happy to visit this blog.
Dot net Training in Bangalore
Salesforce Developer Training in Bangalore | Salesforce Developer Course in Bangalore | Salesforce Training in Bangalore | Salesforce Course in Bangalore
Hadoop Training in Bangalore | Hadoop Corse in Bangalore | Hadoop Training Institute in Bangalore