MVC模式在编程中的应用,是一个很了不起的主意。“数据模型(Model)”可以封装与应用程序的业务逻辑相关的数据及对数据的处理方法;“视图层(View)”能够实现数据有目的的显示;“控制器(Controller)”能够在不同层面间起到组织作用,对应用程序的流程进行控制。

不过,可能你在使用这种三层架构模式的过程中会逐渐迷惑。因为有很多代码你不知道把它放哪,就只好把它放到控制层,最后发现在控制层中塞了太多的代码。

LinkedIn的软件工程师Conrad Irwin也遇到同样的问题,于是他开始使用另一种模式:MOVE,即Models(模型)、Operations(操作)、Views(视图)、Events(事件)。近日Conrad Irwin在个人博客上分享了关于这种模式的一些观点。

概述

Irwin结合上图对MOVE模式先作了简单定义:

Models,封装该应用程序中知道的一切;
Operations,封装该应用程序要做的一切;
Views,帮助用户与应用程序完成交互;
Events,用于安全地连接所有这些组件。

为了避免意大利面条式的代码,图中标示出了对哪种类型的对象进行操作是允许的。例如,视图允许监听由模型产生的事件;操作允许修改模型,但模型不应涉及视图或操作。

Models(模型)

这里以一个“User”对象为原型,它至少应用有一个Email地址,也可能有用户名和电话号码。

在一个MOVE模式的Models中只包装知识。这意味着除了Get和Set功能,它们可以包含检查用户密码是否正确这样的方法,但不会包含把密码保存到数据库或传递给外部API这样的功能,因为后面这些工作将由Operations来完成。

Operations(操作)

对应用程序来说,一个常见的操作是用户登陆。这实际上是由两个子操作组成:首先从用户那里获得邮件地址和密码,然后从数据库载入“user”模型并检查密码是否匹配。

Operations是MOVE模式中的行动者。它负责修改模型,在正确的时间显示正确的视图,以及响应由用户交互引发的事件。在一个分解良好的应用程序中,每个子操作都可以独立运行。

采用这种方式的操作有一点很令人振奋,即程序启动后,整个应用本身就可以被当作一个Operations。它会根据需要生成尽可能多的子操作,其中每个子操作都并行地运行。当所有子操作都完成时,程序也便退出。

Views(视图)

登陆页面即是一个视图,它负责显示一些文本框给用户。当用户点击“登陆”按钮时,视图将产生一个“loginAttempt”事件,其中包含用户输入的用户名和密码。

用户能够看到的内容,以及能感受到的互动都由视图提供支持。它们会以一种用户能理解的形式呈现应用反馈,同时还能将简单的用户交互转换成有意义的事件。更重要的是视图不会直接改变模型,它们只是向Operations发起事件,然后通过监听等待由模型发起的事件。

Events(事件)

当用户登陆时,视图会发起“loginAttempt”事件。在登陆操作完成后,“currentUser”模型会发起一个事件通知应用登陆状态已改变。

事件监听让MOVE(及MVC)实现控制反转,允许模型更新视图。这是一种强大的抽象技巧,允许组件互不干扰地耦合在一起。

为什么是现在?

当然,Conrad Irwin并不想被人认为自己是在暗示MVC模式很差,这种大型应用程序架构在过去的几十年里确实非常成功。不过几十年后的今天,新的编程技术已经变得越来越流行,所以你也会在使用过程中逐渐产生一些疑惑。

MVC模式确实很了不起,但它毕竟是几十年前为老的技术而设计。MOVE模式是在其基础上的升级,让你可以更好地利用当前已有的新工具。

转自:http://www.36kr.com/p/126957.html
原文:http://cirw.in/blog/time-to-move-on

MVC模式已死?何不试试MOVE相关推荐

  1. 基于MVC模式Struts框架研究

    不做web开发多年了, 可偶尔去面试的时候, 还是会问道Struts实现mvc的细节. 很多东西都模糊了. 在网上找了下, 觉得这篇不错, 记下来防止以后用的着. ' 分布式企业应用软件结构复杂.涉及 ...

  2. 【iOS 开发】iOS 开发 简介 (IOS项目文件 | MVC 模式 | 事件响应机制 | Storyboard 控制界面 | 代码控制界面 | Retina 屏幕图片适配)

    一. iOS 项目简介 1. iOS 文件简介 创建一个 HelloWorld 项目, 在这个 IOS 项目中有四个目录 : 如下图; -- HelloWorldTests 目录 : 单元测试相关的类 ...

  3. 关于“VCL已死、RAD已死”答读者问

    这两天在上海参加erlang的大会,来不及写第五小节,先回复一些评论吧.其中最主要的是nanyu的一组评论,大概有三.四篇,写到了不少东西.下面一一道来. 有关评论请参见: http://blog.c ...

  4. 下一代防火墙(NGFW)已死!

    点击上方 "编程技术圈"关注, 星标或置顶一起成长 后台回复"大礼包"有惊喜礼包! 每日英文 You have got to put the past behi ...

  5. 全球互联网排名_全球互联网的梦想已死

    全球互联网排名 重点 (Top highlight) 模式匹配 (Pattern Matching) Welcome back to Pattern Matching, OneZero's weekl ...

  6. mvc模式网页购物车

    本学期学习JSP和Servlet后,老师要求使用MVC模式下编写一个网页购物车,以下是一些主要代码及开发心得 这个是包的截图 先是注册页面,编写一个表单,表单方法调用另一个JSP页面(因为我这个页面是 ...

  7. 百度回应“搜索引擎百度已死”

    1月22日晚,一篇名为<搜索引擎百度已死>的文章刷屏.媒体人方可成在文章中称,百度搜索结果一半以上会指向百度自家产品,尤其是百家号,而百家号充斥着大量营销和质量低劣的内容,也导致百度搜索结 ...

  8. 【案例分享】使用ActiveReports报表工具,在.NET MVC模式下动态创建报表

    提起报表,大家会觉得即熟悉又陌生,好像常常在工作中使用,又似乎无法准确描述报表.今天我们来一起了解一下什么是报表,报表的结构.构成元素,以及为什么需要报表. 什么是报表 简单的说:报表就是通过表格.图 ...

  9. GPT-4加强版Copilot来了!动嘴就能编程,测试申请已开启,网友:程序员已死

    丰色 发自 凹非寺 量子位 | 公众号 QbitAI 用自然语言进行编程的时代真的要来了-- GitHub CEO托马斯·多姆克在官方博客上宣布: 代码辅助工具Copilot进行重大升级,接入GPT- ...

  10. GitHub重磅!GPT-4 Copilot来了!AI帮你编程,网友:程序员已死

    丰色 发自 凹非寺 量子位 | 公众号 QbitAI 用自然语言进行编程的时代真的要来了-- GitHub CEO托马斯·多姆克在官方博客上宣布: 代码辅助工具Copilot进行重大升级,接入GPT- ...

最新文章

  1. MySql之自动同步表结构
  2. UML实践---用例图、顺序图、状态图、类图、包图、协作图
  3. Addin and Automation Development In VB.NET 2003 (3)
  4. pypi.python.org_在Pypi上发布自己的Python包
  5. 【codevs1227】方格取数2,费用流
  6. 无限极业绩_2019中国保健品行业典型企业分析——无限极、康宝莱、汤臣倍健...
  7. 4-1 可复用性概述
  8. 【ArcGIS|空间分析|网络分析】7 使用一支车队服务一组停靠点
  9. 青岛农业大学计算机分数线,青岛农业大学录取分数线2021是多少分(附历年录取分数线)...
  10. 使用流量分析系统进行资产梳理
  11. 阿里云企业邮箱域名注册流程
  12. 怎么理解本征无序态的蛋白质(Intrinsically disordered proteins)
  13. python学习:用两种思路计算质数与合数
  14. Bailian2706 麦森数【大数】
  15. 【计算机视觉】关于计算机视觉(随谈)
  16. Windows程式开发设计指南--图形基础
  17. Fuchsia 的 Rust 代码占比超 50%
  18. 软路由openwrt新手教程
  19. The malloc maleficarum之The House of Spirit漏洞
  20. 大疆无人机安卓Mobile Sdk开发(五)解决M300Rtk H20相机无法获取图片视频的问题

热门文章

  1. 混乱之子第七季/全集Sons of Anarchy迅雷下载
  2. 数据库复习(四)Redis
  3. java高并发唯一订单号_高并发下唯一订单号生成器--雪花算法
  4. 微博营销有什么优势与缺点?如何利用微博开展营销?
  5. php魔方阵,利用C语言玩转魔方阵实例教程
  6. html5 今日头条视频播放,今日头条app设置自动播放视频的方法
  7. 安卓搜不到airpods_airpods忽略设备后再也搜不到了怎么办
  8. Linux中ps命令 ps aux与ps -ef的区别
  9. F1DC2706双模数据透传蓝牙模块AT指令使用介绍
  10. 《黑白团团队》第八次团队作业:Alpha冲刺 第四天