MVVM

前言

按自己的理解,画了简图

图上可以看出:

1,MVP, MVVM 相对于 MVC , 其业务处理的部分(C, P, VM)不再依赖 V层 , 方便进行单元测试。

2,MVVM 与 MVP 的区别则在于不再通过 IView 接口更新 V 层。另外,个人觉得 MVVM 是数据驱动。

而 MVP是数据被动。这是由于MVVM 采用双向binding模式,数据的改变会主动更新到V层。

MVVM

配置之类略过。这里讲讲这两三天的整理。

项目基于1.1.1版本的 lifecycle 框架

api'android.arch.lifecycle:extensions:1.1.1'

kapt'com.android.databinding:compiler:3.1.2'

kapt'android.arch.lifecycle:compiler:1.1.1'

1,在做双向绑定之前,准备好 VM

注:继承 ViewModel,并将需要用于V层绑定数据定义成 MutableLiveData 对象。

2,准备好 V

注:

    1,根标签需修改为 ,lifecycle library 会根据 xml 的名字自动生成布局binding类,比如布局名字为 test.xml, 生成的binding类则是 TestBinding 类。

    2,通过 data 标签引入 VM。接着就可以在控件关联 VM 里的 MutableLiveData 对象。图中是 VM 类里定义的 tips 属性。

3, MVVM 架构的关键,V, VM 之间的双向绑定。

注:

1,TestBinding 类的 testVm 属性是根据 test.xml 的 data 标签里自定义的 variable name 自动生成的。

2,绑定 VM 时,需传入 VM 的类型。如图 TestVM::class.java。

至此,MVVM 的例子就完成了。


完了 ??

实际项目,Activity 多如牛毛。每个都这步骤,这流程,太不科学了。


按照上述流程整理一下

1,VM - BaseViewModel

注:

    1,没什么特别的。主要是引入BaseViewEvent 的概念。由于 MVVM 是可以绑定控件事件的。但是又不想过度的污染 VM 类,所以单独抽出 BaseViewEvent 来放置各种事件。

    2,采用反射自动创建 BaseViewEvent 对象。

2,VM - BaseViewEvent

注:主要定义了两个属性 context 与 上层的 BaseViewModel。 这里互相引用。有点恶心。暂时没想到好办法。属性的主要作用参考注释。

3,V

    V没什么整理,还是原来的V

4,BaseVMActivity - V, VM 之间的双向绑定。

注:

    1,由于 自动生成布局binding类是基于 ViewDataBinding 派生的。所以以泛型的形式 T : ViewDataBinding 传入。

    2,Binding类有了,想在基类 BaseVMActivity 统一绑定 VM。 所以再以泛型的形式 K : BaseViewModel

传入。

    3,initReflect 方法里,获取泛型的类型后生成 VM 对象。

    4,initReflect 方法里,通过反射找到根据 xml自动生成的binding类,再将 VM 对象设置到 xml 自定义的 variable name 里完成双向绑定。


调整之后,再看看

你可能感兴趣的:(MVVM)