MVVM设计模式学习笔记(二)——结合LiveData来搭建MVVM

一. 初识LiveData

1. 什么是LiveData

LiveData是一个数据持有类,它的数据是可以被观察者订阅的,并且能够感知组件(Activity,Fragment,Service)的生命周期(但是必须是处于激活状态才会通知,激活状态:STARTED,RESUMED)。

2. 为什么要用LiveData

  • 保证数据和UI的统一:
    LiveData使用的是观察者模式,并且扮演的是被观察者的角色,当LiveData中的数据发生变化的时候,LiveData会通知观察者(UI)进行实时更新。
  • 减少内存泄漏:
    LiveData能够感知到组件的生命周期,当组件处于DEATROYED状态的时候,会将观察者对象清除掉。
  • 降低了crash的可能性:
    由于LiveData能够感知组件的生命周期的特性,在组件仍未处于激活状态的时候,LiveData并不会通知组件数据的变化。
  • 不需要额外的手动处理生命周期的变化:
    LiveData中自带的感知组件生命周期的功能,不需要开发者在代码中通知LiveData组件的生命周期的状态。
  • 数据和组件的分离:
    组件只负责UI,LiveData负责提供数据,在组件被重新创建的时候(比如屏幕方向的改变),数据由于存放在LiveData中,所以并不会被销毁。
  • 能够实现资源共享:
    可以通过定义一个继承自LiveDta的单例类实现,可以监听一些系统属性的变化。

在MVVM中,可以使用LiveData配合ViewModel实现业务需求。

二. 结合LiveData搭建MVVM框架

LiveData主要在ViewModel中进行使用,通过观察者模式来实现ViewModel通知View的更新。通常也会定义一个Repository类,来做网络请求,数据库查询等工作,可以减轻ViewModel层的代码量和复杂度,这样ViewModel层就能够专注的处理LiveData数据的处理工作了。使用LiveData的MVVM和使用dataBinding的MVVM结构有不同之处:


mvvm-live结构图

上代码说话~

这里新定义了一个SecondActivity的View层,定义了一个UserModel2作为View层的ViewModel,Model层依旧使用原来的UserModel。

1.ViewModel层

public class UserViewModel2 extends ViewModel {

    private UserRepository userRepository = new UserRepository();//Repository处理数据请求
    private MutableLiveData<Boolean> isRefresh = new MutableLiveData<>();

    LiveData<UserModel> userLiveData = Transformations.map(isRefresh, new Function<Boolean, UserModel>() {
        @Override
        public  UserModel apply(Boolean input) {

            if (input){
                return userRepository.refresh();
            }else {
                return userRepository.init();
            }

        }
    });

    public UserViewModel2 setIsRefresh(boolean isRefresh){
        this.isRefresh.setValue(isRefresh);
        return this;
    }

    public LiveData<UserModel> getUserLiveData() {
        return userLiveData;
    }
}

在ViewModel层使用了LiveData和MutableLiveData来分别对数据进行了封装,以便于之后的使用,userLiveData使用了Transformations的map方法,用于在数据传递到观察者之前做出一些符合需求的变动。

  1. Repository类
public class UserRepository {

    //初始化数据
    public UserModel init(){
        MutableLiveData<UserModel> userModelData = new MutableLiveData<>();
        UserModel userModel = new UserModel();
        userModel.setId("111");
        userModel.setName("姓名1");
        userModelData.setValue(userModel);
        return userModel;
    }

    //更新数据
    public UserModel refresh(){
        MutableLiveData<UserModel> userModelData = new MutableLiveData<>();
        UserModel userModel = new UserModel();
        userModel.setId("222");
        userModel.setName("姓名2");
        return userModel;
    }
}

UserRepository类用了init()和refresh()模拟对数据的操作。

  1. View层
class SecondActivity extends AppCompatActivity implements View.OnClickListener {

    private UserViewModel2 model ;
    private TextView tvID;
    private TextView tvName;
    private Button btnClick;


    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_second);

        tvID = findViewById(R.id.tv_id);
        tvName = findViewById(R.id.tv_name);
        btnClick = findViewById(R.id.btn_click);
        btnClick.setOnClickListener(this);

        model = ViewModelProviders.of(this).get(UserViewModel2.class);//获取ViewModel的实例
        //初始化数据的操作
        model.setIsRefresh(false).getUserLiveData().observe(this, new Observer<UserModel>() {
            @Override
            public void onChanged(@Nullable UserModel userModel) {
                tvID.setText(userModel.getId());
                tvName.setText(userModel.getName());
            }
        });
    }

    @Override
    public void onClick(View v) {
        //更新数据的操作
        model.setIsRefresh(true);
    }
}

View层中通过调用ViewModel的方法来通知ViewModel需要做的工作,ViewModel中的LiveData数据可以通过实现observe方法来实现当数据变动则更新UI的操作。

相关笔记传送门:
MVVM设计模式学习笔记(一)——MVVM初体验
LiveData源码学习笔记

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,634评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,951评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,427评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,770评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,835评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,799评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,768评论 3 416
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,544评论 0 271
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,979评论 1 308
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,271评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,427评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,121评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,756评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,375评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,579评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,410评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,315评论 2 352

推荐阅读更多精彩内容