【前端】学习前端框架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方法就可以了。

相关文章
|
10天前
|
人工智能 JavaScript 前端开发
Vue 性能革命:揭秘前端优化的终极技巧;Vue优化技巧,解决Vue项目卡顿问题
Vue在处理少量数据和有限dom的情况下技术已经非常成熟了,但现在随着AI时代的到来,海量数据场景会越来越多,Vue优化技巧也是必备技能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
2月前
|
Dart 前端开发 架构师
【01】vs-code如何配置flutter环境-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈-供大大的学习提升
【01】vs-code如何配置flutter环境-开发完整的社交APP-前端客户端开发+数据联调|以优雅草商业项目为例做开发-flutter开发-全流程-商业应用级实战开发-优雅草央千澈-供大大的学习提升
239 26
|
2月前
|
JavaScript 前端开发 jenkins
抛弃node和vscode,如何用记事本开发出一个完整的vue前端项目
本文探讨了在不依赖Node和VSCode的情况下,仅使用记事本和浏览器开发一个完整的Vue3前端项目的方法。通过CDN引入Vue、Vue Router、Element-UI等库,直接编写HTML文件实现页面功能,展示了前端开发的本质是生成HTML。虽然日常开发离不开现代工具,但掌握这种基础方法有助于快速实现想法或应对特殊环境限制。文章还介绍了如何用Node简单部署HTML文件到服务器,提供了一种高效、轻量的开发思路。
|
4月前
|
JavaScript 前端开发 搜索推荐
Vue的数据驱动视图与其他前端框架的数据驱动方式有何不同?
总的来说,Vue 的数据驱动视图在诸多方面展现出独特的优势,其与其他前端框架的数据驱动方式的不同之处主要体现在绑定方式、性能表现、触发机制、组件化结合、灵活性、语法表达以及与后端数据交互等方面。这些差异使得 Vue 在前端开发领域具有独特的地位和价值。
124 58
|
4月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
76 1
vue学习第一章
|
4月前
|
JavaScript 前端开发 索引
vue学习第三章
欢迎来到瑞雨溪的博客,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中的v-bind指令,包括基本使用、动态绑定class及style等,希望能为你的前端学习之路提供帮助。持续关注,更多精彩内容即将呈现!🎉🎉🎉
76 1
|
4月前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
65 1
vue学习第四章
|
4月前
|
缓存 监控 JavaScript
Vue.js 框架下的性能优化策略与实践
Vue.js 框架下的性能优化策略与实践
|
4月前
|
JavaScript 前端开发
vue学习第五章
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,正向全栈进发。如果你从我的文章中受益,欢迎关注,我将持续分享更多优质内容。你的支持是我最大的动力!🎉🎉🎉
48 1