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也会更新。

相关推荐
codigger9 分钟前
集大成者的下一代编程语言?探秘 Object Sense 如何实现分布式、跨平台与多语言无缝集成
设计模式
小小工匠2 小时前
设计模式 - 组合模式:用树形结构处理对象之间的复杂关系
设计模式·组合模式
是2的10次方啊5 小时前
🏗️ 结构型设计模式:代码架构的魔法师
设计模式
哈基米喜欢哈哈哈6 小时前
设计模式(一)——抽象工厂模式
设计模式·抽象工厂模式
Yang-Never6 小时前
设计模式 -> 策略模式(Strategy Pattern)
android·开发语言·设计模式·kotlin·android studio·策略模式
pointers_syc6 小时前
【设计模式】4.装饰器模式
设计模式·装饰器模式
杨DaB7 小时前
【项目实践】在系统接入天气api,根据当前天气提醒,做好plan
java·后端·spring·ajax·json·mvc
pointers_syc17 小时前
【设计模式】2.策略模式
java·设计模式·策略模式
比特森林探险记18 小时前
Go语言常用的设计模式
开发语言·设计模式·golang
曹朋羽1 天前
spring mvc 整体处理流程原理
java·spring·mvc·spring mvc