Buscar en este blog....

domingo, 31 de julio de 2016

The Difference (and relationship) between MVC and MVP patterns

I wrote this post like one year ago, but I did it in spanish. Yet I'm trying to write also a little more in english. So here it goes.

I think this topic is normally a bit confusing due to the big amount of information that we can easily find in the internet and the short time we can spend to analyze all this information.

The MVC Pattern (Model-View-Controller) is a well-known design pattern which is being used all around the world. In fact, there's no one in the software development who hasn't hear about it. So I'm not gonna explain it. Nevertheless, not so well known is this other pattern called MVP (Model-View-Presenter), although it has gained more terrain in the last years.

At first view one can be tempted to think "Oh, they only changed the Controller of the MVC for the Presenter of the MVP, so it's almost the same thing, but with another name!".

Well.. nothing more far away from the truth! Absolutely not! So, what is it? What is the real difference between them? While I'm not gonna explain the MVP pattern in detail, because there is A LOT of information in internet, I would like to explain what is the relationship between these two patterns. How I see it.

First of all, let's quickly remember what the MVC is about: to separate an application into three conceptually-different parts, so he have:


  • Model: makes reference to data or, better said, to representation of the information. Depending on how you interpret the pattern, the model can be directly bound to the persistence of this information. But in a wider interpretation, it can also mean the whole state of the system in a given moment. So, in its wider interpretation, we can say it embraces both the state of the system and its persistence.
  • Controller: represents the business logic. The rules on which the systems run..
  • View: represents the user interface.

Here it is worth to mention that I don't particularly agree with the separation between "Model" and "Controller", because I think often is kind of difficult -and expensive in terms of time- to totally exclude the model (the data) from the controller (the business logic i.e. the behaviour). However, I'm not saying it can't be done, but rather consider that there is actually a conceptual separaration between them, althought it might be unnecesary (this will be inherent to each situation and system).

Now let's briefly review the what the MVP pattern is about:



  • Model: this model represents the business model. Violá! It's not the same as the model of the MVC, but rather this model includes both the representation of the data and the business logic. That's why we talk about a "Business Model". That is, this model invovles the Model and the Controller of the MVC together.
  • Presenter: this is the director: on one hand it directs the events of the view to the model and on the other it updates the view with the information coming from the model. This concept does not exists directly in the MVC pattern. I mean directly, because is perfectly valid to affirm that this "Presenter" is a part of the "View" in the MVC pattern. That is, this is the logic that we are used to write into the MVC's View, no matter how basic it is!
  • View: The View, according to the MVP, is the silliest and easy-to-write code that we have.  It's just about a "View" that knows his "Presenter", to whom it delegates absolutely everything that happens in it. This View makes nothing but to delegate. The user clicks, the "View" tells the "Presenter" where did the user click. Or the other way: the "Presenter" tell the "View" to fill a ComboBox, the "View" fills the Combo with the information provided. It just does not have business logic at all!

So having this information, if we analyze it a little, we come to the conclusion that both patterns are not mutually excludent. It is not about predicting "We're using the MVC pattern or the MVP pattern", but it could be interesting thinking in a combination of them. That might lead us to something called VPCM (View-Presenter-Controller-Model).

What?! Does it actually exists?! What are we talking about?

Nothing new, to be honest. Maybe the name it's new, it doesn't even exist. But that's not the point. The point is that we are breaking down the View of the MVC in two parts: a "View" who does nothing (but to delegate) and its "Presenter" who does everything for the view. Those are, the View and the Presenter of the MVP. Something like this:


Another way to see this, is the other way: we take the Model of the MVP and we break it down in two new pieces: a Controller (which has the business logic) and a Data Model (which represents the  information). That is, we've just get the Controller and the Model of the MVC pattern. It looks something like this:



As we can see after this analysis, they are NOT mutually excludent patterns: they complement each other! We could say that one emphasize
the Backend, and the other the Frontend. MVC and MVP respectively.

I would like to have some opinions about this analysis and its conclusion.
Cheers!

5 comentarios:

  1. Hello Ignacio,
    I am working on an application in VBA that needs to capture some info in a series of step-by-step User Forms. Like a shopping/ordering machine. You select a product out of a few, then each button in one window leads to a different window, then based on different conditions other smaller windows may pop-up asking for more details. I read about the differences between the 2 main scenarios: MVP and MVC. Now some people say MVC structure suits better as you can have a single Controller governing multiple Views and on the other side MVP requires each View to have its own/separate/dedicated Presenter (I assume each Form needs to have its own View class module). You go even a step further and propose a solution combining the benefits of both worlds. How should I approach the Product Selector UI on multiple interlinked User Forms? Is there anything you would definitely exclude straight away?
    Many thanks,
    Peter

    ResponderEliminar
  2. Hi Ignacio,
    Fantastic concept to take the best of both worlds.
    I am working on an application in VBA that needs to capture some info in a series of step-by-step User Forms. Like a shopping/ordering machine. You select a product out of a few, then each button in one window leads to a different window, then based on different conditions other smaller windows may pop-up asking for more details. I read about the differences between the 2 main scenarios: MVP and MVC. Now some people say MVC structure suits better as you can have a single Controller governing multiple Views and on the other side MVP requires each View to have its own/separate/dedicated Presenter (I assume each Form needs to have its own View class module). How should I approach the Product Selector UI on multiple interlinked User Forms? Is there anything you would definitely exclude straight away?
    Many thanks, Peter

    ResponderEliminar
  3. Hi Ignacio,
    Fantastic concept to take the best of both worlds.
    I am working on an application in VBA that needs to capture some info in a series of step-by-step User Forms. Like a shopping/ordering machine. You select a product out of a few, then each button in one window leads to a different window, then based on different conditions other smaller windows may pop-up asking for more details. I read about the differences between the 2 main scenarios: MVP and MVC. Now some people say MVC structure suits better as you can have a single Controller governing multiple Views and on the other side MVP requires each View to have its own/separate/dedicated Presenter (I assume each Form needs to have its own View class module). How should I approach the Product Selector UI on multiple interlinked User Forms? Is there anything you would definitely exclude straight away?
    Many thanks, Peter

    ResponderEliminar
  4. I am working on an application in VBA that needs to capture some info in a series of step-by-step User Forms. Like a shopping/ordering machine. You select a product out of a few, then each button in one window leads to a different window, then based on different conditions other smaller windows may pop-up asking for more details. I read about the differences between the 2 main scenarios: MVP and MVC. Now some people say MVC structure suits better as you can have a single Controller governing multiple Views and on the other side MVP requires each View to have its own/separate/dedicated Presenter (I assume each Form needs to have its own View class module). How should I approach the Product Selector UI on multiple interlinked User Forms? Is there anything you would definitely exclude straight away?
    Many thanks, Peter

    ResponderEliminar
  5. I am working on an application in VBA that needs to capture some info in a series of step-by-step User Forms. Like a shopping/ordering machine. You select a product out of a few, then each button in one window leads to a different window, then based on different conditions other smaller windows may pop-up asking for more details. I read about the differences between the 2 main scenarios: MVP and MVC. Now some people say MVC structure suits better as you can have a single Controller governing multiple Views and on the other side MVP requires each View to have its own/separate/dedicated Presenter (I assume each Form needs to have its own View class module). How should I approach the Product Selector UI on multiple interlinked User Forms? Is there anything you would definitely exclude straight away? Many thanks, Peter

    ResponderEliminar

Comments are subject to moderation, only in order to avoid insults and disguising things.

Los comentarios están sujetos a moderación, solo con el fin de evitar insultos y cosas por el estilo.