MVC,MVP,MVVM

阮一峰的网络日志

MVC

  • 视图(view):用户界面
  • 控制器(controller):业务逻辑
  • 模型(model):数据保存

1472147-20180908114538863-624927237.png

  1. view传送指令到contriller
  2. controller完成业务逻辑后改变model状态
  3. model将新的数据发送到view,用户得到反馈

MVP

1472147-20180908114611242-1828354190.png

  1. 各部分之间的通信都是双向的
  2. view与model不发生联系,通过presenter传递
  3. view非常薄,不部署任何业务逻辑。presenter非常厚,部署所有业务逻辑

MVVM

1472147-20180908102901824-667234415.png

MVVM采用的是双向绑定:view的变动都会自动反映在viewmodel中,反之亦然。

vue双向绑定原理

Vue.js 是采用 Object.defineProperty 的 getter 和 setter,并结合观察者模式来实现数据绑定的。当把一个普通 Javascript 对象传给 Vue 实例来作为它的 data 选项时,Vue 将遍历它的属性,用 Object.defineProperty 将它们转为 getter/setter。用户看不到 getter/setter,但是在内部它们让 Vue 追踪依赖,在属性被访问和修改时通知变化。

1472147-20180908102944144-45089139.png

转载于:https://www.cnblogs.com/loveyt/p/9608679.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值