当前位置: 首页 > news >正文

MVC和MVVM这两种设计模式的区别

一、MVC和MVVM是什么?

MVC是Model-View-Controller的简写,Model就是模型,对应后端数据,View就是视图对应用户界面,Controller就是控制器,对应页面的业务逻辑。
MVC的工作机制原理就是,用户操作会请求服务器路由,路由就会调用对应的控制器来处理,控制器就会获取后台数据,将结果返回给前端,进行页面渲染。


MVVM是Model-View-ViewModel的简写,它本质上就是MVC的改进版,ViewModel的存在目的是抽离Controller中展示的业务逻。在MVVM中,ViewModel主要关注视图的数据绑定和展示逻辑,而在MVC中,Controller则更多地涉及业务逻辑的处理 。

二、MVC和MVVM的区别

第一,MVC是单向的,而MVVM是双向的,并且是自动的,也就是数据发生变化自动同步视图,视图发生变化自动同步数据。
第二个,解决了 MVC 中大量的 DOM 操作使页面渲染性能降低,加载速度变慢,影响用户体验等问题。
第三个,在数据频繁更新的时候,采用了虚拟DOM,减少过度渲染,提高性能。 

三、对应的常见框架

MVC框架:

AngularJS:AngularJS是一个由Google开发的JavaScript前端框架,它采用了MVC设计模式,使得开发者可以更好地组织和管理前端代码。

MVVM框架:

Vue.js:Vue.js是一个流行的JavaScript框架,采用MVVM设计模式,提供了数据驱动的界面和组件化的开发方式,使得开发者能够更容易地构建交互性强、响应迅速的应用程序。

React.js:React.js虽然本身并非严格意义上的MVVM框架,但其采用了虚拟DOM以及单向数据流的概念,可以与一些状态管理库(如Redux)结合,实现与MVVM类似的数据流管理。

http://www.lryc.cn/news/339140.html

相关文章:

  • 淘宝app端商品详情数据采集(商品价格,商品库存,商品销量,商品优惠券)
  • 第42篇:随机存取存储器(RAM)模块<一>
  • 在Java中实现记录1000万用户连续7天登录的功能,可以使用Redis的Bitmap来跟踪每个用户的登录状态
  • 深入探讨VIVE OpenXR:为Unity开发者的全面指南
  • 【Altium Designer 20 笔记】PCB线宽与过孔尺寸
  • 基于java的社区生活超市管理系统
  • 51单片机入门_江协科技_27~28_OB记录的自学笔记_AT24C02数据存储秒表
  • LeetCode-热题100:169. 多数元素
  • 汽车维修类中译英的英语翻译
  • java中的List,ArrayList和LinkedList集合
  • RESTful API与Web应用程序构建:原理与实践
  • 输了,腾讯golang一面凉了
  • 如何通过代码签名证书加强安全防护?
  • Docker速成:新手变专家!
  • numpy/arrayobject.h: No such file or directory
  • 前端大文件分块上传、断点续传
  • 使用新版FLIR (FLIR_ADAS_v2) 数据集创建yolo格式数据集(目标检测)
  • PHP发票查验接口未返回正确信息的原因、发票ocr识别接口
  • RA4000CE为汽车动力传动系统提供解决方案
  • 算法中的二阶差分
  • 第十五届蓝桥杯Java A组参赛总结
  • springCloudAlibaba集成seata实战(分布式事物详解)
  • VRTK/SteamVR手柄震动功能
  • MYSQL索引优化方法
  • 多模态 ——LLaVA 集成先进图像理解与自然语言交互GPT-4的大模型
  • 文献学习-33-一个用于生成手术视频摘要的python库
  • Unity Android 2021 Release-Notes
  • Java8新特性--lambda表达式
  • C/C++中设置随机数
  • ARM 三个小灯闪烁