MVVM架构模式

目录

MVVM

数据绑定方式

实现方式

Model

View

ViewModel


数据绑定方式

vue:: 数据劫持和发布-订阅模式:

Object.defineProperty() 方法来劫持(监控)各属性的 gettersetter ,并在数据(对象)发生变动时通知订阅者,触发相应的监听回调。

Observer------》数据监听器。对数据对象属性进行监听,变化后通知订阅者

Compiler------》指令解析器。扫描模板,指令解析,绑定事件

Watcher------》订阅者。关联Observer和Compile,能够订阅并收到属性变动的通知,通过执行Update()执行指令绑定的相应操作,更新视图。

实现方式

view和Model采用双向绑定,实现view和model数据变化会自动更新

二者不联系,实现解耦

Model

数据层,它仅仅关注数据本身,不关心任何操作

View

视图层,仅仅负责与用户交互(数据、指令的接收与显示)

ViewModel

与MVP不同的是,没有了View为Presente提供的接口,之前由Presenter负责的View和Model之间的数据同步交给了ViewModel中的数据绑定进行处理,当Model发生变化,ViewModel就会自动更新;ViewModel变化,Model也会更新。

相关推荐
ZouZou老师1 小时前
C++设计模式之命令模式:以家具生产为例
c++·设计模式·命令模式
laocooon5238578862 小时前
C++ 设计模式概述及常用模式
开发语言·c++·设计模式
SadSunset3 小时前
(12)GoF设计模式
设计模式
化作繁星4 小时前
前端设计模式详解
前端·设计模式
ZouZou老师4 小时前
C++设计模式之责任链模式:以家具生产为例
c++·设计模式·责任链模式
赵得C5 小时前
软件设计师前沿考点精讲:新兴技术与性能优化实战
java·开发语言·分布式·算法·设计模式·性能优化
白衣鸽子6 小时前
【基础数据篇】数据等价裁判:Comparer模式
后端·设计模式
Charlo6 小时前
Open-AutoGLM Windows 安装部署教程
算法·设计模式·github
TDengine (老段)6 小时前
TDengine 存储引擎:极速、高压缩、零冗余
android·大数据·数据库·设计模式·时序数据库·tdengine·涛思数据
每次的天空7 小时前
Android车机开发——内存优化操作
android·学习·设计模式