模型视图控制器有哪些选择?

时间:2020-03-05 18:42:27  来源:igfitidea点击:

在大学学习和跟随SO的发展过程中,我听到了很多有关Model-View-Controller架构设计模式的信息。我什至在不了解MVC模式之前就无意中使用了MVC模式,并且仍然在我的日常工作中使用它。从我所看到的来看,它可能是当今使用的最受欢迎的模式。不过,我还不太了解的是可以使用替代MVC的替代模式。有哪些选项,我们出于什么原因决定通过MVC使用它们?我也想知道它们通常用于的系统类型。最后,使用它们带来的利弊是什么?

解决方案

回答

  • 被动检视-http://martinfowler.com/eaaDev/PassiveScreen.html
  • 监督控制器-http://martinfowler.com/eaaDev/SupervisingPresenter.html
  • 模型查看呈现器-http://martinfowler.com/eaaDev/ModelViewPresenter.html
My personal favorite is the Passive View. More testable than others I've seen including MVC.

回答

我偶尔会看到没有C的MVC,其中视图侦听模型数据中的更改并相应地更改呈现,并且模型中的方法绑定到视图的事件处理程序。

对于必须将视图与数据紧密结合的项目(例如,当存在与模型或者模型属性直接相关的可视组件时),这很有用,因为它可以剔除"中间人"。

但是,我认为许多人会争辩说,这仍然是MVC,只是一个混合版本,并且在视图和模型之间建立的绑定是控制器逻辑。

回答

好吧,这里有Model-View-Presenter,但是我想我们会发现MVC最常见的"替代"实际上是缺乏适当的分离。举一个极端的例子,考虑经典的ASP页,其中在同一文件中并排找到HTML,VBScript和SQL。 (这不是ASP的轻拍,我们会在其他语言中找到很多这样的示例。)

回答

尽管以上答案是正确的,但我认为更重要的是要注意到90%的所有软件开发人员都完全不知道"设计模式"一词。他们只是开始编写代码。

挑战不是选择最佳设计方法,而是说服其他人设计具有价值。

回答

我们可以使用当前的ASP.NET框架滚动自己的MVC,并且仍然保留回发模型。

http://www.codeproject.com/KB/aspnet/RollingYourOwnMVCwithASP.aspx

回答

Presentation-Abstraction-Control(PAC)系列模式,其中接口/交互由代理层次结构处理。

维基百科的文章不是很好
http://en.m.wikipedia.org/wiki/Presentation-abstraction-control

回答

在Lift网络框架中,我们使用"查看优先"方法。基本上,一个视图由一个或者多个代码段(有点类似于控制器)组成,并且代码段可以嵌套。这与HTML和Scala的内置XML处理功能配合得很好。

回答

其他一些架构模式包括MVC。

分层系统

TCP / IP

面向对象的组织

Model-View-Controller,Presentation-abstraction-Control,Model View Presenter和Model View ViewModel。

例如ASP.NET的MVC,Ruby on Rails等。

基于事件的隐式调用

浏览器环境(DOM)

管道和过滤器架构

Unix管道

储存库

表驱动口译员

我们可能还会发现Garlan&Shaw撰写的有关Software Architecture的论文非常不错。

另一个值得注意的链接是Wikipedia上有关建筑模式的文章。

回答

好吧,现在已经很老了。我想再说一遍(为了获得更多信息的信息)是PresenterFirst patrern

这是有关同一内容的更多信息:

http://en.wikipedia.org/wiki/Presenter_First

http://www.atomicobject.com/pages/Presenter+First

高温超导