官术网_书友最值得收藏!

The Model-View-Presenter pattern

Model-View-Presenter is a variation of the original MVC pattern that we discussed previously. Both MVC and MVP target the separation of concerns but they are different on many fundamental aspects. The presenter in MVP has the necessary logic for the view. Any invocation from the view gets delegated to the presenter. The presenter also observes the model and updates the views when the model updates. Many authors take the view that because the presenter binds the model with views, it also performs the role of a traditional controller. There are various implementations of MVP and there are no frameworks that offer classical MVP out of the box. In implementations of MVP, the following are the primary differences that separate MVP from MVC:

  • The view has no reference to the model
  • The presenter has a reference to the model and is responsible for updating the view when the model changes

MVP is generally implemented in two flavors:

  • Passive view: The view is as na?ve as possible and all the business logic is within the presenter. For example, a plain Handlebars template can be seen as a passive view.
  • Supervising controller: Views mostly contain declarative logic. A presenter takes over when the simple declarative logic in the view is insufficient.

The following figure depicts MVP architecture:

主站蜘蛛池模板: 射阳县| 敖汉旗| 蓬莱市| 汪清县| 松阳县| 喀什市| 阜平县| 慈溪市| 苗栗市| 高邮市| 九江市| 三门峡市| 涞水县| 惠水县| 巴东县| 新野县| 通化市| 阜平县| 普宁市| 深圳市| 桓台县| 雷波县| 于都县| 罗城| 额济纳旗| 邮箱| 乌苏市| 咸丰县| 拉萨市| 博罗县| 秦皇岛市| 清水县| 孙吴县| 防城港市| 乌鲁木齐县| 台山市| 萨迦县| 合肥市| 淮南市| 北川| 广德县|