为什么MVC不是一种设计模式?

Posted siwenyu

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为什么MVC不是一种设计模式?相关的知识,希望对你有一定的参考价值。

引用一段话

GoF (Gang of Four,四人组, 《Design Patterns: Elements of Reusable Object-Oriented Software》/《设计模式》一书的作者:Erich Gamma、Richard Helm、Ralph Johnson、John Vlissides)并没有把MVC提及为一种设计模式,而是把它当做“一组用于构建用户界面的类集合”。在他们看来,它其实是其它三个经典的设计模式的演变:观察者模式(Observer)(Pub/Sub), 策略模式(Strategy)和组合模式(Composite)。根据MVC在框架中的实现不同可能还会用到工厂模式(Factory)和装饰器(Decorator)模式。我在另一本免费的书“javascript Design Patterns For Beginners”中讲述了这些模式,如果你有兴趣可以阅读更多信息。

正如我们所讨论的,models表示应用的数据,而views处理屏幕上展现给用户的内容。为此,MVC在核心通讯上基于推送/订阅模型(惊讶的是 在很多关于MVC的文章中并没有提及到)。当一个model变化时它对应用其它模块发出更新通知(“publishes”),订阅者 (subscriber)——通常是一个Controller,然后更新对应的view。观察者——这种自然的观察关系促进了多个view关联到同一个 model。

对于感兴趣的开发人员想更多的了解解耦性的MVC(根据不同的实现),这种模式的目标之一就是在一个主题和它的观察者之间建立一对多的关系。当这个 主题改变的时候,它的观察者也会得到更新。Views和controllers的关系稍微有点不同。Controllers帮助views对不同用户的输 入做不同的响应,是一个非常好的策略模式列子。

 

这里已经说明了,官方说这是三中设计模式的合体,不是一种纯粹的设计模式,还可能跟工厂模式装饰器模式有染,这里有一篇好文章:

为什么MVC不是一种设计模式? ---比较Backbone和Ext4.x在MVC实现上的差异

以上是关于为什么MVC不是一种设计模式?的主要内容,如果未能解决你的问题,请参考以下文章

为什么要用MVC

SpringMVC

从MVC框架看MVC架构的设计

狂神说 spring mvc 完整版

springmvc学习

MVC模式