一、ViewModel的介绍
ViewModel 具有生命周期意识,会自动存储和管理 UI 相关的数据,即使设备配置发生变化后数据还会存在,我们就不需要在 onSaveInstanceState 保存数据,在 onCreate 中恢复数据了,使用 ViewModel 这部分工作就不需要我们做了,很好地将视图与逻辑分离开来。
ViewModel生命周期
相信大家都看过这张ViewModel生命周期图。从 OnCreate 获取到 ViewModel 之后,它会一直存在,直到该 ViewModel 绑定的 View 彻底 onDestory。如何理解这个彻底就有点意思了,得看源码。
二、ViewModel的简单使用
添加的依赖:
implementation "android.arch.lifecycle:extensions:1.1.1"
gradle plugin:
使用一:默认方式
TestViewModel.java
public class TestViewModel extends ViewModel {
private MutableLiveData<String> currentName;
public int i;
public MutableLiveData<String> getCurrentName() {
if (currentName == null) {
currentName = new MutableLiveData<>();
}
return currentName;
}
}
of方法内部也是借助ViewModelProvider来new一个ViewModelProvider的:
new ViewModelProvider(activity.getViewModelStore(), factory)
但是这种我没指定factory的情况,最终我们写的ViewModel类是通过这个工厂类默认的AndroidViewModelFactory的create方法反射创建的。
使用二、自定义工厂类继承ViewModelProvider.NewInstanceFactory
public class ArticleViewModel extends ViewModel {
private final ArticleItemRepository mArticleItemRepository;
//列表数据的LiveData
public MutableLiveData<List<ArticleInfo>> articleList;
//请求状态的LiveData
public MutableLiveData<NetWorkStatus> mStatusLiveData;
public ArticleViewModel(ArticleItemRepository repository) {
this.mArticleItemRepository = repository;
articleList = new MutableLiveData<>();
mStatusLiveData = new MutableLiveData<>();
}
public void getArticleList(ArticleRequestBean bean) {
mArticleItemRepository.getArticleList(bean, articleList, mStatusLiveData);
}
}
这种方式就是我们自定义factory,然后重写create来创建的。
三、效果
效果就是,view中的数据是使用了ViewModel身上的数据的话,无论当前页面的配置如何改变,只要不是彻底销毁,而是改变配置,这个数据都会一直存在,不会随着生命周期的重建而重新赋值。(目前我知道的配置变化就是一种:屏幕旋转)
这是页面刚打开的时候的截图。
下面通过旋转屏幕来改变TestActivity的配置,会重新走生命周期(在清单文件里面我没设置android:configChanges属性)
我点击最下面两个控件改变初始值的截图。
总结:ViewModel的使用其实很简单,就几行代码,要理解为什么ViewModel的生命周期这么长就得看源码,下一篇讲解ViewModel的原理。