为什么23种设计模式里面没有MVC?

Posted

tags:

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

作者:lorio
链接:https://www.zhihu.com/question/27738109/answer/100241918
来源:知乎
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

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没有被GOF当作【一种】模式来对待了吧?

因为它实际上是三种模式的合体

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

如何通过鹿哥提车快速理解mvc设计模式

在MVC设计模式中,Model1与Model2之间的关系?

MVC模式

使用基本MVC2模式创建新闻网站

spingMVC之我见 MVC框架模式

使用mvc模式设计的web应用程序具有以下优点,除了?