书接前文,前篇文章简略了介绍了一下Caliburn.Micro(简称CM)的Action,这篇文章继续讨论CM的下一个Feature:Convention。

  Convention,翻译过来叫公约、协定。公约,一般指行为规范,达成共识的多方共同遵守的一个约定。在CM中,Convention主要用来做配对,匹配。这个配对,主要是指View和ViewModel之间的配对,前篇文章已经提过,CM是基于MVVM模式的,MVVM(Model-View-ViewModel)中,Model是用来保存数据的,相对来说它比较固定,View和ViewModel之间的关系有一些变化,简单的说一说。

View-First or ViewModel-First

  MVVM中,ViewModel的作用是储存View的状态,封装Model的数据。ViewModel是PresentationModel模式发展而来的,ViewModel中并不会储存所有的View的状态,它只存储可能被修改的View的状态。WPF的出现,主要提供了两个技术,让ViewModel的出现成为了可能:

  1. 数据绑定,WPF提供了数据绑定,View绑定到ViewModel,使用ViewModel作为它的DataContext。当ViewModel中存储的View状态发生改变的时候,View会自动刷新状态。
  2. Command,WPF提供了ICommand,当用户操作View时,会通过Command把操作传递给ViewModel。

  View的两大功能,显示数据和操作数据,分别被抽象出来,它的状态也被保存在ViewModel中,由于使用了数据绑定,View通过DataContext来关联ViewModel,两者之间是松耦合的,这也是MVVM模式的精彩之处。那么回到本篇文章要讨论的点上,View和ViewModel如何关联?谁来找到谁?View-First or ViewModel-First?

ViewModel-First

  通常情况下,都会推荐大家ViewModel-First。设计时先设计好ViewModel,再通过数据模板(DataTemplate)来生成对应的View。这样做的好处是可以随时替换View,单元测试时可以Mock一个View测试。CM框架提供了ViewLocator来通过ViewModel定位对应的View,它的方法如下:

> LocateForModel
> LocateForModelType 

相关文章: