浅谈前端MVC与MVVC模式

最早接触MVC模式的时候还是学习JAVA框架时候了解的,当时M表示modal层,负责数据块,V表示View层,负责页面渲染,C表示Contrllor,负责控制前后交互。

这个是JAVA的MVC模式!

那么前端的MVC又表示的是什么呢?

在前端的MVC模式中,M还是表示Modal层,负责与后台交互数据,V表示View,负责页面上DOM的渲染,C表示绑定在DOM元素上的事件,当Controllor中的事件被调用,会去调用Modal中的数据,然后交给View重新渲染数据

现在的前端MVVM模式又是什么一个模式呢?

目前前端框架中,最为出色的要属Vue和React了,这俩个框架的核心理念都是数据驱动页面渲染,同时他们都是MVVM模式的框架,MVVM模式中的M还是固定表示Modal,V还是表死View,这俩个基本都是不会发生变化,一个页面必然需要数据和渲染俩个部分,那么变化的是如何将Modal渲染到View的过程变了,在MVVM模式中,将View和Modal绑定在一起,只要Modal发生了变化,View就会自动更新,不需要我们认为的再去写如何操作DOM更新的过程了

转载于:https://juejin.im/post/5c80aacb51882533d6708838

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MVCMVVC 是两种常见的软件架构模式,主要用于构建用户界面。 MVC 是 Model-View-Controller 的缩写,是指模型-视图-控制器的架构。在 MVC 架构中,用户界面被划分为三个部分: - Model(模型):表示应用程序的状态和业务逻辑。 - View(视图):表示应用程序的用户界面,负责将模型的数据呈现给用户。 - Controller(控制器):负责响应用户的操作,接收用户的输入并根据输入更新模型和视图。 MVVC 是 Model-View-ViewModel 的缩写,是 MVC 的变体。MVVC 架构中多了一个 ViewModel 层,它负责将模型的数据转化为视图能够使用的格式。ViewModel 与 View 和 Model 之间的交互是通过数据绑定来实现的,ViewModel 不直接操作视图,而是通过数据绑定将模型的状态呈现给视图。 MVCMVVC 的区别在于,MVVC 多了一个 ViewModel 层,ViewModel 负责将模型的数据转化为视图能够使用的格式,同时通过数据绑定将模型的状态呈现给视图。由于 ViewModel 不直接操作视图,因此 MVVC 的代码 ### 回答2: MVCMVVC是两种常见的软件架构模式,用于将应用程序的不同部分分离开来,提供更好的可维护性和扩展性。 MVC(Model-View-Controller)是一种经典的软件架构模式,将应用程序分为三个组件:模型(Model)、视图(View)和控制器(Controller)。模型负责处理数据逻辑,视图负责用户界面的展示,控制器负责处理用户输入和业务逻辑。MVC的主要特点是逻辑清晰、分工明确,能够有效分离关注点,提高代码的可维护性。然而,由于控制器负责处理用户输入和业务逻辑,在复杂的应用中往往导致控制器变得臃肿,难以维护。 MVVM(Model-View-ViewModel)是一种相对较新的软件架构模式,将应用程序分为三个组件:模型(Model)、视图(View)和视图模型(ViewModel)。模型依然负责处理数据逻辑,视图负责用户界面的展示,而视图模型负责将模型数据转化为视图所需的格式,并处理用户的操作请求,然后将结果反馈给模型。MVVM的主要特点是数据双向绑定,视图模型与视图的绑定使得数据的更新可以自动反映到视图上,大大简化了视图和模型之间的通信,提高了代码的可维护性和可测试性。 区别MVC和MVVM的关键在于视图和模型之间的通信方式。在MVC中,视图通过控制器与模型进行通信,而在MVVM中,视图模型通过双向数据绑定与模型进行通信。MVVM通过数据绑定的方式,实现了视图和模型之间的解耦,降低了代码的复杂性。此外,MVVM还提供了命令绑定的机制,将用户操作转化为模型中的具体业务逻辑,进一步简化了代码的编写。 总之,MVC和MVVM都是用于分离应用程序中不同部分的架构模式MVC较为传统,MVVM相对较新且强调数据绑定,通过不同的通信方式实现了代码的可维护性和可测试性的提升。选择使用哪种架构模式应根据具体的项目需求和开发团队的熟悉程度进行评估。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值