【前端】学习前端框架Vue中的MVVM之LiveData

简介: 上一篇学习了MVVM,这一篇来学习下LiveData知识点

学习和使用MVVM的好处还有很多,但是对MVVM为什么会有这些好处还有很多疑问,
MVVM为什么要分5层?
MVVM每一层都是干什么的?
LiveData怎么用?
MVVM具体怎么落地开发?

有问题不可怕,就怕没有问题,那么接下来就请带着这些问题开始继续学习吧。

什么是LiveData

LiveData是MVVM框架中做数据绑定的工具。本质上是个观察者模式实现的一套有生命周期感知能力的数据监听方案。LiveData不是一个单独的东西,其背后还有Lifecycle、Observe等知识。LiveData就是一个设置数据并且通过Observe监听数据的工具。

LiveData在MVVM中的作用

LiveData在MVVM中负责监听数据变化,比如有个View需要数据填充,然后这个View作为LiveData的观察者,当DataSource中有数据更新时,通过LiveData通知所有的观察者,这样View就会收到数据。这样数据就更新到View层了。所以显而易见,LiveData就是MVVM中的数据命脉,没有LiveData,MVVM就无法正常运作。

LiveData具体怎么用,有哪些用法

LiveData本身是一个抽象类,有两个子类MutableLiveData和MediatorLiveData,MutableLiveData倒是没有什么特别的,基本就是一个套壳实现类,MediatorLiveData也没有什么特别的,多了几个方法, 其中比较常用的是addSource方法,这个后面会再介绍。
LiveData的使用非常简单,主要分为两个,一个是观察数据,一个是设置数据。
观察数据代码:

LiveData<String> liveData=new MutableLiveData<>();
liveData.observe(this,new Observe(){
    @Override
        public void onChanged(String s){
        //do something
        }
});

observe方法有两个参数,一个是接收一个LifecycleOwner另一个是接收Observe对象。这个LifecycleOwne参数本质上是将视图组件(Activity、Fragment)的生命周期传递到LiveData中去,这样LiveData就会有生命周期感知功能,比如发起一个网络请求,在回调之前页面销毁了,那么LiveData就会感知到页面销毁了从而取消数据的通知。这样就会从很多场景避免由于页面销毁而导致崩溃的发生。

再来看看怎么设置数据:

LiveData<String> liveData=new MutableLiveData<>();
liveData.setValue("test");

再来看看另一个设置数据的方法

LiveData<String> liveData=new MutableLiveData<>();
liveData.postValue("test");

可以看到,上面有两个设置数据的方法,一个是setValue一个是postValue,这两个方法唯一的区别就是postValue在源码中会强制让runnable方法在主线程中运行。所以我们可以根据业务场景来使用这两个方法。
另外还有一个MediatorLiveData有一个addSource方法,这个方法接收一个LiveData和observe对象做为参数,代表LiveData可以做为数据源被另一个LiveData观察。
接下来看看LiveData有哪些特点

LiveData特点

1、LiveData具有生命周期感知能力,读者可以大胆使用而不用担心忽视视图组件(activity、fragment)的生命周期。
2、LiveData是粘性的,所谓的粘性就是指监听方法在设置数据之后,依然可以监听到数据的变化,翻阅源码可以发现,每次设置observe监听方法的时候其实是遍历一遍监听方法的,然后将最近的值回调给缓存的所有监听方法。
3、MediatorLiveData的addSource本质上就是LiveData.addObserve,所以你可发现LiveData可以add多个不同的observe实例,并且触发回调时按照添加顺序进行回调。
4、当然LiveData可以添加observe也可以删除observe,调用remove方法就可以了。

相关文章
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
50 1
vue学习第一章
|
2月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
34 1
|
2月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
41 1
vue学习第四章
|
2月前
|
JavaScript 前端开发 算法
vue学习第7章(循环)
欢迎来到瑞雨溪的博客,一名热爱JavaScript和Vue的大一学生。本文介绍了Vue中的v-for指令,包括遍历数组和对象、使用key以及数组的响应式方法等内容,并附有综合练习实例。关注我,将持续更新更多优质文章!🎉🎉🎉
32 1
vue学习第7章(循环)
|
2月前
|
JavaScript 前端开发
vue学习第九章(v-model)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript与Vue的大一学生,自学前端2年半,正向全栈进发。此篇介绍v-model在不同表单元素中的应用及修饰符的使用,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
36 1
vue学习第九章(v-model)
|
2月前
|
JavaScript 前端开发 开发者
vue学习第十章(组件开发)
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文深入讲解Vue组件的基本使用、全局与局部组件、父子组件通信及数据传递等内容,适合前端开发者学习参考。持续更新中,期待您的关注!🎉🎉🎉
50 1
vue学习第十章(组件开发)
|
2月前
|
缓存 监控 JavaScript
Vue.js 框架下的性能优化策略与实践
Vue.js 框架下的性能优化策略与实践
|
2月前
|
JavaScript 前端开发
vue学习第五章
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,正向全栈进发。如果你从我的文章中受益,欢迎关注,我将持续分享更多优质内容。你的支持是我最大的动力!🎉🎉🎉
30 1
|
2月前
|
JavaScript 前端开发
vue学习第六章(条件显示)
欢迎来到我的博客!我是瑞雨溪,一名自学前端两年半的大一学生,擅长JavaScript与Vue,正向全栈进发。本篇介绍v-if、v-else、v-elseif及v-show的使用方法,附带实例演示。希望我的分享能帮到你,欢迎关注,持续更新中!🎉🎉🎉
31 1
|
2月前
|
分布式计算 JavaScript 前端开发
vue学习第8章(vue的购物车案例)
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,正向全栈进发。本篇分享一个综合练习小demo,包括目录结构、HTML、JS及CSS代码,通过增删商品实现总价计算。关注我,获取更多前端知识!🎉🎉🎉
40 1