当前位置:首页 > 科技  > 软件

一图详解五种前端架构

来源: 责编: 时间:2023-12-04 17:25:10 310观看
导读无论是 iOS 还是 Android 开发,前端架构模式都是应用程序开发中最常用的模式之一。开发人员引入这些模式是为了克服早期模式的局限性。那么,它们有什么不同呢?又解决了什么问题呢?1. MVC (Model-View-Controller)MVC 是最

无论是 iOS 还是 Android 开发,前端架构模式都是应用程序开发中最常用的模式之一。开发人员引入这些模式是为了克服早期模式的局限性。那么,它们有什么不同呢?又解决了什么问题呢?chE28资讯网——每日最新资讯28at.com

chE28资讯网——每日最新资讯28at.com

1. MVC (Model-View-Controller)

MVC 是最古老的模式,可追溯到近 50 年前。chE28资讯网——每日最新资讯28at.com

  • Model:封装了数据以及对数据的操作。
  • View:定义了数据的展示,并负责接收用户输入。
  • Controller:定义了对用户操作的响应。作为 Model 和 View 的连接,处理用户操作和数据上的改变。

MVC 模式的发明大大降低了前端数据和事件的管理难度。chE28资讯网——每日最新资讯28at.com

MVC 模式的局限性在于所有事件都在 Controller 中处理,使得其比较臃肿。并且 View 和 Controller 的绑定过于紧密,不利于代码复用。chE28资讯网——每日最新资讯28at.com

2. MVP (Model-View-Presenter)

在 MVP 模式中,View 和 Model 不能直接通信,必须通过 Presenter 来更新数据。这样,View 和 Model 就解耦了,可以作为单纯的展示层而存在。chE28资讯网——每日最新资讯28at.com

MVP 模式由于需要做大量的数据同步工作,Presenter 也会和 View 绑定过于紧密。chE28资讯网——每日最新资讯28at.com

3. MVVM (Model-View-ViewModel)

MVVM 由微软提出,用 ViewModel 的概念接管了 Presenter 的数据同步工作,这样省去了很多在 Presenter 里面的模版代码,架构和代码逻辑更加清晰。chE28资讯网——每日最新资讯28at.com

4. MVVM-C (Model-View-ViewModel-Coordinator)

虽然 MVVM 省去了数据绑定的模版代码,但其在架构分层上只是用 ViewModel 取代了 Presenter,所以在实现时还是会有大量逻辑的堆砌,这常常被称为“垃圾抽屉”。并且 ViewModel 通常也不能在多个 View 间重用。这时我们可以加入一个 Coordinator 来协调 ViewModel 之间的跳转,来提高其复用性。chE28资讯网——每日最新资讯28at.com

5. VIPER (View-Interactor-Presenter-Entity-Router)

VIPER 架构并不是基于 MVC 的改进,它是全新的架构模式,也是架构职责划分最明确的。然而其复杂度也是最大的,不适合较小规模的项目。chE28资讯网——每日最新资讯28at.com

  • View:定义了数据的展示,并负责接收用户输入。
  • Entity:定义数据对象,但是不包括对数据访问和操作。
  • Interactor:负责从 Entity 获取数据,执行数据操作逻辑。这里的数据结构独立于界面显示。
  • Presenter:从 Interactor 获取数据,展示给用户。
  • Router:负责模块间的跳转。

总体看来,每种模式都需要处理以下 3 个问题:chE28资讯网——每日最新资讯28at.com

  1. 数据源:一般从后端服务和存储中获得,其数据模型接近于后端。
  2. 数据绑定:将一个或多个数据源整形处理为符合前端展示需要的数据,其数据模型可以一步到位接近前端模型,或者可以是一个中间状态方便页面间复用。
  3. 事件响应:响应用户的操作,并对数据进行操作。

各个模式根据具体需求采用了不同的分层和解耦。我们需要根据需求来选取合适的架构模式。chE28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-37659-0.html一图详解五种前端架构

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 探索 Python 编程世界:五个神奇库助力提升开发效率

下一篇: 解锁 C++ 并发编程的钥匙:探索 Atomic 变量

标签:
  • 热门焦点
  • 6月安卓手机性价比榜:Note 12 Turbo断层式碾压

    6月份有一个618,虽然这是京东周年庆的日子,但别的电商也都不约而同的跟进了,反正促销没坏处,厂商和用户都能满意。618期间一些产品也出现了历史低价,那么各个价位段的产品性价比
  • 十个可以手动编写的 JavaScript 数组 API

    JavaScript 中有很多API,使用得当,会很方便,省力不少。 你知道它的原理吗? 今天这篇文章,我们将对它们进行一次小总结。现在开始吧。1.forEach()forEach()用于遍历数组接收一参
  • 量化指标是与非:挽救被量化指标扼杀的技术团队

    作者 | 刘新翠整理 | 徐杰承本文整理自快狗打车技术总监刘新翠在WOT2023大会上的主题分享,更多精彩内容及现场PPT,请关注51CTO技术栈公众号,发消息【WOT2023PPT】即可直接领取
  • 每天一道面试题-CPU伪共享

    前言:了不起:又到了每天一到面试题的时候了!学弟,最近学习的怎么样啊 了不起学弟:最近学习的还不错,每天都在学习,每天都在进步! 了不起:那你最近学习的什么呢? 了不起学弟:最近在学习C
  • 共享单车的故事讲到哪了?

    来源丨海克财经与共享充电宝相差不多,共享单车已很久没有被国内热点新闻关照到了。除了一再涨价和用户直呼用不起了。近日多家媒体再发报道称,成都、天津、郑州等地多个共享单
  • 中国家电海外掘金正当时|出海专题

    作者|吴南南编辑|胡展嘉运营|陈佳慧出品|零态LT(ID:LingTai_LT)2023年,出海市场战况空前,中国创业者在海外纷纷摩拳擦掌,以期能够把中国的商业模式、创业理念、战略打法输出海外,他们依
  • Android 14发布:首批适配机型公布

    5月11日消息,谷歌在今天凌晨举行了I/O大会,本次发布会谷歌带来了自家的AI语言模型PaLM 2、谷歌Pixel Fold折叠屏、谷歌Pixel 7a手机,同时发布了Androi
  • OPPO K11搭载长寿版100W超级闪充:26分钟充满100%

    据此前官方宣布,OPPO将于7月25日也就是今天下午14:30举办新品发布会,届时全新的OPPO K11将正式与大家见面,将主打旗舰影像,和同档位竞品相比,其最大的卖
  • 最薄的14英寸游戏笔记本电脑 Alienware X14已可以购买

    2022年1月份在国际消费电子展(CES2022)上首次亮相的Alienware新品——Alienware X14现在已经可以购买了,这款笔记本电脑被誉为世界上最薄的 14 英寸游戏笔
Top