乐趣区

关于前端:对MVCMVPMVVM的理解

#### MVC 模式的意思是,软件系统能够分成三个局部。如图所示:


视图(View):用户界面。
控制器(Controller):业务逻辑。
模型(Model):数据保留。
#### 三者之间的分割如图所示:

#### 解释一下三者之间的通信:
View 传送指令到 Controller
Controller 实现业务逻辑后,要求 Model 扭转状态
Model 将新的数据发送到 View,用户失去反馈
所有通信都是单向的(逆时针)。
### MVP 模式将 Controller 改名为 Presenter(次要业务逻辑),同时扭转了通信方向。如图所示:

#### 三者之间的分割:
各局部之间的通信,都是双向的(顺时针)。
View 与 Model 不产生分割,都通过 Presenter 传递。
View 十分薄,不部署任何业务逻辑,称为 “ 被动视图 ”(Passive View),即没有任何主动性,而 Presenter 十分厚,所有逻辑都部署在那里。
### MVVM 模式将 Presenter 改名为 ViewModel,基本上与 MVP 模式完全一致,如图所示:

mvvm 惟一的区别是,它采纳双向绑定(data-binding):View 的变动,主动反映在 ViewModel,反之亦然。Angular 和 Ember 都采纳这种模式。

退出移动版