理解MVVM

MVVM是什么

  • MVVM模式,顾名思义即Model-View-ViewModel模式。它萌芽于2005年微软推出的基于Windows的用户界面框架WPF,前端最早MVVM框架Knockout在2010年发布。
  • Model层:对应数据层的域模型,它主要做域模型的同步。通过Ajax/fetch等API完成客户端和服务端业务Model的同步。在层间关系里,它主要用于抽象出ViewModel中视图的Model。
  • View层:作为视图模板存在,在MVVM里,整个View是一个动态模板。除了定义结构、布局外,它展示的是ViewModel层的数据和状态。View层不负责处理状态,View层做的是 数据绑定的声明、指令的声明、事件绑定的声明。
  • ViewModel层:把View需要的层数据暴露,并对View层的数据绑定声明、指令声明、事件绑定声明负责,也就是处理View层的具体业务逻辑。ViewModel底层会做好绑定属性的监听。当ViewModel中数据变化,View层会得到更新;而当View中声明了数据的双向绑定(通常是表单元素),框架也会监听View层(表单)值得变化。一旦值变化,View层绑定的ViewModel中的数据也会得到自动更新。

这里对MVVM理解做一个简化:
视图请求数据,将请求发送至VModel,在Vmodel的两端具有监听机制,直接调用模型的数据,一端改变全部改变,利用数据劫持,结合订阅者和发布者模式,实现数据的双向绑定

MVVM的优缺点

优点:
  • 分离视图(View)和模型(model),降低代码耦合,提高视图或者逻辑的重要性:比如视图(View)可以独立于Model变化和修改,一个ViewModel可以绑定不同的“View”上,当View变化的时候Model不可以不变,当Model变化的时候View也可以不变。你可以把一些视图逻辑放在一个ViewModel里面,让很多view重用这段视图逻辑
  • 提高可测试性:ViewModel的存在可以帮助开发者更好的编写测试代码
  • 自动更新dom:利用双向绑定,数据更新后视图自动更新,让开发者从繁琐的手动dom中解放

缺点

  • Bug很难被调试:因为使用双向绑定的模式,当你看到界面异常了,有可能是你View的代码有Bug,也可能是Model的代码有问题。数据绑定使得一个位置的bug被快速的递到别的位置,要定位原始出问题的地方就变得不那么容易了。另外,数据绑定的声明是指令式地写在View的模板当中的,这些内容是没办法去打断点debug的
  • 一个大的模块中model也会很大,虽然使用方便了也很容易保证了数据的一致性,当时长期持有,不释放内存就造成了花费更多的内存
  • 对于大型的图形应用程序,视图状态较多,ViewModel的构建和维护的成本都会比较高
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值