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

相关文章
|
1月前
|
存储 JavaScript 前端开发
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
【10月更文挑战第21天】 vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
vue3的脚手架模板你真的了解吗?里面有很多值得我们学习的地方!
|
17天前
|
JavaScript 前端开发 UED
vue学习第二章
欢迎来到我的博客!我是一名自学了2年半前端的大一学生,熟悉JavaScript与Vue,目前正在向全栈方向发展。如果你从我的博客中有所收获,欢迎关注我,我将持续更新更多优质文章。你的支持是我最大的动力!🎉🎉🎉
26 3
|
17天前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript和Vue的大一学生。自学前端2年半,熟悉JavaScript与Vue,正向全栈方向发展。博客内容涵盖Vue基础、列表展示及计数器案例等,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
36 2
|
1月前
|
前端开发 JavaScript 开发者
React与Vue:前端框架的巅峰对决与选择策略
【10月更文挑战第23天】React与Vue:前端框架的巅峰对决与选择策略
|
1月前
|
前端开发 JavaScript 数据管理
React与Vue:两大前端框架的较量与选择策略
【10月更文挑战第23天】React与Vue:两大前端框架的较量与选择策略
|
2月前
|
JavaScript 前端开发 算法
前端优化之超大数组更新:深入分析Vue/React/Svelte的更新渲染策略
本文对比了 Vue、React 和 Svelte 在数组渲染方面的实现方式和优缺点,探讨了它们与直接操作 DOM 的差异及 Web Components 的实现方式。Vue 通过响应式系统自动管理数据变化,React 利用虚拟 DOM 和 `diffing` 算法优化更新,Svelte 通过编译时优化提升性能。文章还介绍了数组更新的优化策略,如使用 `key`、分片渲染、虚拟滚动等,帮助开发者在处理大型数组时提升性能。总结指出,选择合适的框架应根据项目复杂度和性能需求来决定。
|
1月前
|
前端开发 JavaScript 开发者
React与Vue:前端框架的巅峰对决与选择策略
【10月更文挑战第23天】 React与Vue:前端框架的巅峰对决与选择策略
|
Web App开发 JavaScript 前端开发
Vue框架快速入门
Vue是现在最流行的前端框架之一,而且相对于其他两个框架React和Angular来说也更加易学,而且它的作者是国人,中文文档也很完善。当然Vue框架算是比较高级的框架,所以在使用过程中还需要JavaScript、JavaScript 2015、WebPack、NodeJS、npm、ESLint、JavaScript单元测试框架等其他知识和框架的使用方法。
1342 0
|
12天前
|
缓存 JavaScript 前端开发
vue学习第四章
欢迎来到我的博客!我是瑞雨溪,一名热爱JavaScript与Vue的大一学生。本文介绍了Vue中计算属性的基本与复杂使用、setter/getter、与methods的对比及与侦听器的总结。如果你觉得有用,请关注我,将持续更新更多优质内容!🎉🎉🎉
28 1
vue学习第四章
|
12天前
|
JavaScript 前端开发
vue学习第九章(v-model)
欢迎来到我的博客,我是瑞雨溪,一名热爱JavaScript与Vue的大一学生,自学前端2年半,正向全栈进发。此篇介绍v-model在不同表单元素中的应用及修饰符的使用,希望能对你有所帮助。关注我,持续更新中!🎉🎉🎉
26 1
vue学习第九章(v-model)