SlideShare a Scribd company logo
Model View Controller
                     Design Pattern


Guided By:                            Submitted By :
Dr. Avinash Panwar                    Abhishek Yadav
                                      Shashwat S Mehta
                                      Sourabh Jain
HOW
MVC ?


WHAT’s
MVC ?



WHY
MVC ?
Overview:
 1.   Design Patterns
 2.   Why MVC
 3.   What is MVC
 4.   Alternative Patterns
 5.   Implementation Frameworks
 6.   Benefits and Disadvantages




                                   3
Problem
Without Separation of concerns a
developer has to rely and wait for
the feeds of others to complete his
tasks. Productivity --




                                      Solution
                                      With separation of concerns by
                                      MVC, he can build applications
                                      faster, Unit test them easily
                                      without any involvement of other
                                      developers. Productivity ++

                                                     4
MVC
Pattern? Architecture? Framework?




                          5
Pattern:


“ Each pattern is a three-part rule, which expresses a relation
between a certain context (design context), a certain system of
forces which occurs repeatedly in that context (recurring
design problem), and a certain software configuration which
allows these forces to resolve themselves (solution). “




                                                6
Architectural Pattern:


Fundamental structural organization for software systems.

Architectural patterns are high-level strategies that concerns large-scale
components, the global properties and mechanisms of a system.

“At the highest level, there are the architecture patterns that define the
overall shape and structure of software applications. Down a level is the
architecture that is specifically related to the purpose of the software
application. Yet another level down resides the architecture of the modules
and their interconnections. This is the domain of design patterns, packages,
components, and classes.”




                                                           7
Framework:


A software framework is a universal, reusable software platform used to
develop applications, products and solutions.




                                                         8
A Generic MVC Framework
                          9
Model
• represents an application’s data and contains the logic for accessing
  and manipulating that data

• groups related data and operations for providing a specific service

• services accessed by the controller for querying or effecting a change
  in the model state.

• The model notifies the view when a state change occurs in the model.

• The Model layer represents the part of your application that
  implements the business logic


                                                       10
View
• responsible for rendering the state of the model

• forwards user input to the controller

• View renders a presentation of modeled data

• can be used to deliver a wide variety of formats depending on your
  needs




                                                     11
Controller
• responsible for intercepting and translating user input into actions
  to be performed by the model

• responsible for selecting the next view based on user input and the
  outcome of model operations

• handles requests from users

• can be seen as managers taking care that all needed resources for
  completing a task are delegated to the correct workers



                                                      12
Example

      13
Alternatives
         14
THE
MODEL-VIEW-PRESENTER
       (MVP)
      PATTERN


               15
The Taligent Model-View-Presenter
              Pattern




                         16
Components
 • Model refers to the data and business functionality of the application

 • Selections are components which specify what portion of the data within
   the Model is to be operated upon

 • Commands are components which define the operations which can be
   performed on the data

 • View is the visual representation of the Model and is comprised of the
   screens and widgets used within an application

 • Interactors are components which address how user events are mapped
   onto operations performed on the Model

 • Presenter is a component which orchestrates the overall interaction of the
   other components within the application



                                                           17
The Dolphin Smalltalk Model-
   View-Presenter Pattern




                      18
Components

• The Model refers to the data and business functionality of the
  application.

• The View is the visual representation of the Model and is comprised
  of the screens and widgets used within an application.

• The Presenter is a component which contains the presentation
  logic which interacts with the Model.




                                                     19
The Supervising Controller Pattern




                         20
Components

• The View is the visual components used within an application such
  as screens and widgets.

• The Controller is a component which processes user events and
  the complex presentation logic within an application.




                                                   21
The Passive View Pattern




                    22
Components

• The View is the visual components used within an application such
  as screens and widgets

• The Controller is a component which processes user events and
  the presentation logic within an application




                                                   23
The
Presentation-Abstraction-Control
             (PAC)
             Pattern

                       24
25
Components

• The Presentation is the visual representation of a
  particular abstraction within the application


• The Abstraction is the business domain functionality
  within the application


• The Control is a component which maintains consistency
  between the abstractions within the system and their
  presentation to the user in addition to communicating with
  other Controls within the system


                                               26
MVC
Implementations

            27
MVC Implementation in J2EE

Used for separating business layer
functionality represented by JavaBeans or EJBs
(the model) from the presentation layer
functionality represented by JSPs (the view)
using an intermediate servlet based
controller.


                                  28
29
30
Model 1 and Model 2

In the design of Java Web applications, there are two
commonly used design models, referred to as Model 1
and Model 2




                                        31
Model 1 Architecture
• a request is made to a JSP or servlet

• JSP or servlet handles all responsibilities for the
  request

• commonly used in smaller, simple task applications

• not conducive to large-scale application development


                                             32
Model 2 Architecture
• separates the display of content from the logic used to obtain
  and manipulate the content

• requests from the client browser are passed to the controller

• controller performs any logic necessary to obtain the correct
  content for display

• places the content in the request

• view then renders the content passed by the controller


                                                33
ASP.NET MVC features
•   Separation of application tasks, testability, and test-driven development by default

•   An extensible and pluggable framework

•   powerful URL-mapping component lets you build applications that have
    comprehensible and searchable URLs

•   Support for existing ASP.NET features

•   MVC’s model works through URL routing to specific controller methods and any
    operation routes back to a specific method in the controller.




                                                                    34
GUI Frameworks
•   XPages – for IBM Lotus Notes/Domino
•   GTK+ provides models and views, while clients implement the controllers through
    signals
•   Microsoft Foundation Class Library (MFC) – called the document/view
    architecture
•   ASP.NET MVC Framework – reusing jQuery libraries and proprietary Microsoft
    Ajax libraries
•   Microsoft Composite UI Application Block – part of the Microsoft Enterprise
    Library
•   Oracle Application Development Framework – Oracle ADF
•   Java Swing
•   Adobe Flex
•   Wavemaker – open source, browser-based development tool based on MVC
•   Visual FoxExpress is a Visual FoxPro MVC framework


                                                               35
Web Frameworks
•   XForms has an integrated MVC architecture with an integral dependency graph, frees
    the programmer from specifically having to perform either push or pull operations.

•   Ruby on Rails

•   Django - A complete Python web application framework, prefers to call its MVC
    implementation MTV, for model-template-view.

•   Zend Framework - An open-source PHP 5-based framework featuring a MVC layer
    and a broad-spectrum of loosely coupled components.

•   Joomla - free and open source content management system (CMS) for publishing
    content on the World Wide Web and intranets and a MVC Web application framework
    that can also be used independently.

•   CodeIgniter - simple, light, fast, open source MVC framework for building websites
    using PHP.


                                                                36
• CakePHP - A web application framework modeled after the concepts of
  Ruby on Rails.

• ASP.NET MVC Framework

• Swing - uses a model-delegator pattern, where the view and controller
  are combined, but the model is separate

• Java Hibernate

• Spring MVC Framework

• Struts

• Java Server Faces (JSF)

• Web Dynpro for ABAP & Java
                                                       37
Benefits


 • Supports Test Driven Development


 • Supports multiple views


 • Accommodates change

                                 38
Disadvantages

 • Complexity

 • Cost of frequent updates




                              39
References:

1. A Timeless Way of Hacking: R Gabriel, in Core J2EE Patterns, Pearson Education.
2. Erich Gamma, Richard Helm, Ralph Johnson and John Vlissides in Design Patterns:
   Elements of Reusable Object-Oriented Software,AddisonWesley Professional,
   November 10, 1994
3. Roger S Pressman in Software Engineering: A Practitioner's Approach (International
   Edition),McGraw-Hill, January 20, 2009
4. Understanding Model-View-Controller in CakePHP cookbook 2.x, Available:
   http://book.cakephp.org/2.0/en/cakephp-overview/understanding-model-view-
   controller.html
5. David Lloyd, Expresso Developer's Guide, What is MVC, Available:
   http://www.jcorporate.com/expresso/doc/edg/edg_WhatIsMVC.html
6. Wikipedia, Model View Controller, Available:
   http://en.wikipedia.org/wiki/Model%E2%80%93view%E2%80%93controller
7. Microsoft ASP.NET Team, ASP.NET MVC Overview, Available:
   http://www.asp.net/mvc/tutorials/overview/asp-net-mvc-overview
8. MSDN, Model View Controller, Available http://msdn.microsoft.com/en-
   us/library/ff649643.aspx
9. John T.Emmatty, Differences between MVC and MVP for Beginners, Available:
   http://www.codeproject.com/Articles/288928/Differences-between-MVC-and-MVP-for-
   Beginners


                                                               40
Thank you !!

More Related Content

PPTX
Introduction to blazemeter and jmeter
PPTX
requirement documentation
PPTX
Generic process model
PDF
Software Engineering - chp2- requirements specification
PPT
Software Reengineering
PDF
Introduction to software engineering
DOCX
Concept of Failure, error, fault and defect
PPT
Software Testing
Introduction to blazemeter and jmeter
requirement documentation
Generic process model
Software Engineering - chp2- requirements specification
Software Reengineering
Introduction to software engineering
Concept of Failure, error, fault and defect
Software Testing

What's hot (20)

PPTX
Software Test Metrics and Measurements
PPTX
Demilitarized Zone (DMZ) in computer networking
PPTX
Software testing.ppt
PPT
Chapter14
ODP
The Art Of Debugging
PDF
Configuration testing
PPS
Formal Methods
PPTX
Software Engineering- Types of Testing
PPTX
Software quality assurance
PPTX
Software Quality Assurance
PPTX
Software Testing - Part 1 (Techniques, Types, Levels, Methods, STLC, Bug Life...
PPTX
Functional vs Non-functional Requirements - Which comes first?
PDF
Unit and integration Testing
PPT
1.1 The nature of software.ppt
PPT
Performance Engineering Basics
PPTX
DevOps Introduction
PDF
B Shaped model
PPTX
SDLC - Software Development Life Cycle
PDF
SE2018_Lec 18_ Design Principles and Design Patterns
PPTX
SRS(software requirement specification)
Software Test Metrics and Measurements
Demilitarized Zone (DMZ) in computer networking
Software testing.ppt
Chapter14
The Art Of Debugging
Configuration testing
Formal Methods
Software Engineering- Types of Testing
Software quality assurance
Software Quality Assurance
Software Testing - Part 1 (Techniques, Types, Levels, Methods, STLC, Bug Life...
Functional vs Non-functional Requirements - Which comes first?
Unit and integration Testing
1.1 The nature of software.ppt
Performance Engineering Basics
DevOps Introduction
B Shaped model
SDLC - Software Development Life Cycle
SE2018_Lec 18_ Design Principles and Design Patterns
SRS(software requirement specification)
Ad

Viewers also liked (20)

PPT
MVC ppt presentation
PPT
Mvc architecture
PDF
Model View Controller (MVC)
PPT
Why MVC?
ODP
Why Use MVC?
PPT
ASP.NET MVC Presentation
PPTX
Introduction to ASP.NET MVC
PPTX
ASP.NET MVC Presentation
PDF
Creating MVC Application with backbone js
ODP
Sprint Portlet MVC Seminar
DOCX
Repository Pattern in MVC3 Application with Entity Framework
PDF
Getting to know Laravel 5
PDF
Struts presentation
PPTX
Introduction to Laravel Framework (5.2)
ODP
Creando APIs REST con Spring Boot
PPT
MVC Architecture
PDF
MVC architecture
PDF
Laravel 5
PDF
Desarrolla tu primera api con spring boot
PDF
The mHealth + Telehealth World 2014
MVC ppt presentation
Mvc architecture
Model View Controller (MVC)
Why MVC?
Why Use MVC?
ASP.NET MVC Presentation
Introduction to ASP.NET MVC
ASP.NET MVC Presentation
Creating MVC Application with backbone js
Sprint Portlet MVC Seminar
Repository Pattern in MVC3 Application with Entity Framework
Getting to know Laravel 5
Struts presentation
Introduction to Laravel Framework (5.2)
Creando APIs REST con Spring Boot
MVC Architecture
MVC architecture
Laravel 5
Desarrolla tu primera api con spring boot
The mHealth + Telehealth World 2014
Ad

Similar to MVC Seminar Presantation (20)

PDF
PPTX
Architectural Design & Patterns
PPTX
Mvc pattern and implementation in java fair
PPTX
MVC.pptx
PPSX
Software Design Patterns
PPTX
Cs 1023 lec 2 (week 1) edit 1
PPTX
Cs 1023 lec 2 (week 1) edit 1
PDF
Spring vs. asp.net mvc
PPTX
MVC 6 Introduction
PPTX
Introduction to Model-View-Controller Framework.pptx
PPTX
Jsp with mvc
PDF
Web frameworks
ODP
Mvc
PPTX
5_6163495906206292160 for study purpose.pptx
PPTX
MVC architecture by Mohd.Awais on 18th Aug, 2017
PDF
Twisting the Triad
PDF
IRJET- MVC Framework: A Modern Web Application Development Approach and Working
PPTX
Pattern oriented architecture for web based architecture
PPTX
MVC - Introduction
PDF
Mvc Architecture in a web based application
Architectural Design & Patterns
Mvc pattern and implementation in java fair
MVC.pptx
Software Design Patterns
Cs 1023 lec 2 (week 1) edit 1
Cs 1023 lec 2 (week 1) edit 1
Spring vs. asp.net mvc
MVC 6 Introduction
Introduction to Model-View-Controller Framework.pptx
Jsp with mvc
Web frameworks
Mvc
5_6163495906206292160 for study purpose.pptx
MVC architecture by Mohd.Awais on 18th Aug, 2017
Twisting the Triad
IRJET- MVC Framework: A Modern Web Application Development Approach and Working
Pattern oriented architecture for web based architecture
MVC - Introduction
Mvc Architecture in a web based application

Recently uploaded (20)

PDF
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
PDF
Review of recent advances in non-invasive hemoglobin estimation
PDF
solutions_manual_-_materials___processing_in_manufacturing__demargo_.pdf
PDF
Dropbox Q2 2025 Financial Results & Investor Presentation
PPTX
Big Data Technologies - Introduction.pptx
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PPTX
MYSQL Presentation for SQL database connectivity
PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PPT
Teaching material agriculture food technology
PDF
Approach and Philosophy of On baking technology
PPTX
Understanding_Digital_Forensics_Presentation.pptx
PDF
Empathic Computing: Creating Shared Understanding
DOCX
The AUB Centre for AI in Media Proposal.docx
PDF
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
PDF
[발표본] 너의 과제는 클라우드에 있어_KTDS_김동현_20250524.pdf
PDF
Advanced methodologies resolving dimensionality complications for autism neur...
PDF
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PDF
Unlocking AI with Model Context Protocol (MCP)
PDF
The Rise and Fall of 3GPP – Time for a Sabbatical?
7 ChatGPT Prompts to Help You Define Your Ideal Customer Profile.pdf
Review of recent advances in non-invasive hemoglobin estimation
solutions_manual_-_materials___processing_in_manufacturing__demargo_.pdf
Dropbox Q2 2025 Financial Results & Investor Presentation
Big Data Technologies - Introduction.pptx
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
MYSQL Presentation for SQL database connectivity
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
Teaching material agriculture food technology
Approach and Philosophy of On baking technology
Understanding_Digital_Forensics_Presentation.pptx
Empathic Computing: Creating Shared Understanding
The AUB Centre for AI in Media Proposal.docx
Build a system with the filesystem maintained by OSTree @ COSCUP 2025
[발표본] 너의 과제는 클라우드에 있어_KTDS_김동현_20250524.pdf
Advanced methodologies resolving dimensionality complications for autism neur...
Bridging biosciences and deep learning for revolutionary discoveries: a compr...
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
Unlocking AI with Model Context Protocol (MCP)
The Rise and Fall of 3GPP – Time for a Sabbatical?

MVC Seminar Presantation

  • 1. Model View Controller Design Pattern Guided By: Submitted By : Dr. Avinash Panwar Abhishek Yadav Shashwat S Mehta Sourabh Jain
  • 3. Overview: 1. Design Patterns 2. Why MVC 3. What is MVC 4. Alternative Patterns 5. Implementation Frameworks 6. Benefits and Disadvantages 3
  • 4. Problem Without Separation of concerns a developer has to rely and wait for the feeds of others to complete his tasks. Productivity -- Solution With separation of concerns by MVC, he can build applications faster, Unit test them easily without any involvement of other developers. Productivity ++ 4
  • 6. Pattern: “ Each pattern is a three-part rule, which expresses a relation between a certain context (design context), a certain system of forces which occurs repeatedly in that context (recurring design problem), and a certain software configuration which allows these forces to resolve themselves (solution). “ 6
  • 7. Architectural Pattern: Fundamental structural organization for software systems. Architectural patterns are high-level strategies that concerns large-scale components, the global properties and mechanisms of a system. “At the highest level, there are the architecture patterns that define the overall shape and structure of software applications. Down a level is the architecture that is specifically related to the purpose of the software application. Yet another level down resides the architecture of the modules and their interconnections. This is the domain of design patterns, packages, components, and classes.” 7
  • 8. Framework: A software framework is a universal, reusable software platform used to develop applications, products and solutions. 8
  • 9. A Generic MVC Framework 9
  • 10. Model • represents an application’s data and contains the logic for accessing and manipulating that data • groups related data and operations for providing a specific service • services accessed by the controller for querying or effecting a change in the model state. • The model notifies the view when a state change occurs in the model. • The Model layer represents the part of your application that implements the business logic 10
  • 11. View • responsible for rendering the state of the model • forwards user input to the controller • View renders a presentation of modeled data • can be used to deliver a wide variety of formats depending on your needs 11
  • 12. Controller • responsible for intercepting and translating user input into actions to be performed by the model • responsible for selecting the next view based on user input and the outcome of model operations • handles requests from users • can be seen as managers taking care that all needed resources for completing a task are delegated to the correct workers 12
  • 13. Example 13
  • 15. THE MODEL-VIEW-PRESENTER (MVP) PATTERN 15
  • 17. Components • Model refers to the data and business functionality of the application • Selections are components which specify what portion of the data within the Model is to be operated upon • Commands are components which define the operations which can be performed on the data • View is the visual representation of the Model and is comprised of the screens and widgets used within an application • Interactors are components which address how user events are mapped onto operations performed on the Model • Presenter is a component which orchestrates the overall interaction of the other components within the application 17
  • 18. The Dolphin Smalltalk Model- View-Presenter Pattern 18
  • 19. Components • The Model refers to the data and business functionality of the application. • The View is the visual representation of the Model and is comprised of the screens and widgets used within an application. • The Presenter is a component which contains the presentation logic which interacts with the Model. 19
  • 21. Components • The View is the visual components used within an application such as screens and widgets. • The Controller is a component which processes user events and the complex presentation logic within an application. 21
  • 22. The Passive View Pattern 22
  • 23. Components • The View is the visual components used within an application such as screens and widgets • The Controller is a component which processes user events and the presentation logic within an application 23
  • 25. 25
  • 26. Components • The Presentation is the visual representation of a particular abstraction within the application • The Abstraction is the business domain functionality within the application • The Control is a component which maintains consistency between the abstractions within the system and their presentation to the user in addition to communicating with other Controls within the system 26
  • 28. MVC Implementation in J2EE Used for separating business layer functionality represented by JavaBeans or EJBs (the model) from the presentation layer functionality represented by JSPs (the view) using an intermediate servlet based controller. 28
  • 29. 29
  • 30. 30
  • 31. Model 1 and Model 2 In the design of Java Web applications, there are two commonly used design models, referred to as Model 1 and Model 2 31
  • 32. Model 1 Architecture • a request is made to a JSP or servlet • JSP or servlet handles all responsibilities for the request • commonly used in smaller, simple task applications • not conducive to large-scale application development 32
  • 33. Model 2 Architecture • separates the display of content from the logic used to obtain and manipulate the content • requests from the client browser are passed to the controller • controller performs any logic necessary to obtain the correct content for display • places the content in the request • view then renders the content passed by the controller 33
  • 34. ASP.NET MVC features • Separation of application tasks, testability, and test-driven development by default • An extensible and pluggable framework • powerful URL-mapping component lets you build applications that have comprehensible and searchable URLs • Support for existing ASP.NET features • MVC’s model works through URL routing to specific controller methods and any operation routes back to a specific method in the controller. 34
  • 35. GUI Frameworks • XPages – for IBM Lotus Notes/Domino • GTK+ provides models and views, while clients implement the controllers through signals • Microsoft Foundation Class Library (MFC) – called the document/view architecture • ASP.NET MVC Framework – reusing jQuery libraries and proprietary Microsoft Ajax libraries • Microsoft Composite UI Application Block – part of the Microsoft Enterprise Library • Oracle Application Development Framework – Oracle ADF • Java Swing • Adobe Flex • Wavemaker – open source, browser-based development tool based on MVC • Visual FoxExpress is a Visual FoxPro MVC framework 35
  • 36. Web Frameworks • XForms has an integrated MVC architecture with an integral dependency graph, frees the programmer from specifically having to perform either push or pull operations. • Ruby on Rails • Django - A complete Python web application framework, prefers to call its MVC implementation MTV, for model-template-view. • Zend Framework - An open-source PHP 5-based framework featuring a MVC layer and a broad-spectrum of loosely coupled components. • Joomla - free and open source content management system (CMS) for publishing content on the World Wide Web and intranets and a MVC Web application framework that can also be used independently. • CodeIgniter - simple, light, fast, open source MVC framework for building websites using PHP. 36
  • 37. • CakePHP - A web application framework modeled after the concepts of Ruby on Rails. • ASP.NET MVC Framework • Swing - uses a model-delegator pattern, where the view and controller are combined, but the model is separate • Java Hibernate • Spring MVC Framework • Struts • Java Server Faces (JSF) • Web Dynpro for ABAP & Java 37
  • 38. Benefits • Supports Test Driven Development • Supports multiple views • Accommodates change 38
  • 39. Disadvantages • Complexity • Cost of frequent updates 39
  • 40. References: 1. A Timeless Way of Hacking: R Gabriel, in Core J2EE Patterns, Pearson Education. 2. Erich Gamma, Richard Helm, Ralph Johnson and John Vlissides in Design Patterns: Elements of Reusable Object-Oriented Software,AddisonWesley Professional, November 10, 1994 3. Roger S Pressman in Software Engineering: A Practitioner's Approach (International Edition),McGraw-Hill, January 20, 2009 4. Understanding Model-View-Controller in CakePHP cookbook 2.x, Available: http://book.cakephp.org/2.0/en/cakephp-overview/understanding-model-view- controller.html 5. David Lloyd, Expresso Developer's Guide, What is MVC, Available: http://www.jcorporate.com/expresso/doc/edg/edg_WhatIsMVC.html 6. Wikipedia, Model View Controller, Available: http://en.wikipedia.org/wiki/Model%E2%80%93view%E2%80%93controller 7. Microsoft ASP.NET Team, ASP.NET MVC Overview, Available: http://www.asp.net/mvc/tutorials/overview/asp-net-mvc-overview 8. MSDN, Model View Controller, Available http://msdn.microsoft.com/en- us/library/ff649643.aspx 9. John T.Emmatty, Differences between MVC and MVP for Beginners, Available: http://www.codeproject.com/Articles/288928/Differences-between-MVC-and-MVP-for- Beginners 40