【前端】学习前端框架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 算法
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(八):学习transition过渡属性;本文学习property模拟、duration过渡时间指定、delay时间延迟 等多个参数
transition过渡属性 早期在Web中要实现动画效果,都是依赖于JavaScript或Flash来完成。 但在CSS3中新增加了一个新的模块transition,它可以通过一些简单的CSS事件来触发元素的外观变化, 让效果显得更加细腻。简单点说,就是通过鼠标经过、获得焦点,被点击或对元素任何改变中触发, 并平滑地以动画效果改变CSS的属性值。 在CSS中创建简单的过渡效果可以从以下几个步骤来实现: 在默认样式中声明元素的初始状态样式; 声明过渡元素最终状态样式,比如悬浮状态; 在默认样式中通过添加
216 1
|
2月前
|
前端开发 JavaScript 算法
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(七):学习ransform属性;本文学习 rotate旋转、scale缩放、skew扭曲、tanslate移动、matrix矩阵 多个参数
transform变形 css3在原来的基础上新增了变形和动画相关属性,通过这些属性可以实现以前需要大段JavaScript才能实现的 功能。 CSS3的变形功能可以对HTML组件执行位移、旋转、缩放、倾斜4种几何变换,这样的变换可以控制HTML组件 呈现出丰富的外观。 借助于位移、旋转、缩放、倾斜这4种几何变换,CSS3提供了transition动画。 transition动画比较简单,只要指定HTML组件的哪些CSS属性需要使用动画效果来执行变化,并指定动画时间,就可保证动画播放。 比transitio
154 1
|
7月前
|
JavaScript 前端开发 Java
制造业ERP源码,工厂ERP管理系统,前端框架:Vue,后端框架:SpringBoot
这是一套基于SpringBoot+Vue技术栈开发的ERP企业管理系统,采用Java语言与vscode工具。系统涵盖采购/销售、出入库、生产、品质管理等功能,整合客户与供应商数据,支持在线协同和业务全流程管控。同时提供主数据管理、权限控制、工作流审批、报表自定义及打印、在线报表开发和自定义表单功能,助力企业实现高效自动化管理,并通过UniAPP实现移动端支持,满足多场景应用需求。
675 1
|
8月前
|
移动开发 前端开发 JavaScript
Vue与React两大前端框架的主要差异点
以上就是Vue和React的主要差异点,希望对你有所帮助。在选择使用哪一个框架时,需要根据项目的具体需求和团队的技术栈来决定。
496 83
|
7月前
|
JavaScript 前端开发 编译器
Vue与TypeScript:如何实现更强大的前端开发
Vue.js 以其简洁的语法和灵活的架构在前端开发中广受欢迎,而 TypeScript 作为一种静态类型语言,为 JavaScript 提供了强大的类型系统和编译时检查。将 Vue.js 与 TypeScript 结合使用,不仅可以提升代码的可维护性和可扩展性,还能减少运行时错误,提高开发效率。本文将介绍如何在 Vue.js 项目中使用 TypeScript,并通过一些代码示例展示其强大功能。
307 22
|
6月前
|
JavaScript API 开发者
Vue框架中常见指令的应用概述。
通过以上的详细解析,你应该已经初窥Vue.js的指令的威力了。它们是Vue声明式编程模型的核心之一,无论是构建简单的静态网站还是复杂的单页面应用,你都会经常用到。记住,尽管Vue提供了大量预定义的指令,你还可以创建自定义指令以满足特定的需求。为你的Vue应用程序加上这些功能增强器,让编码变得更轻松、更愉快吧!
136 1
|
7月前
|
人工智能 自然语言处理 JavaScript
用 CodeBuddy 搭建Vue框架 像呼吸一样简单
本文介绍如何借助 CodeBuddy 快速创建 Vue 项目。CodeBuddy 是一款支持自然语言编程的工具,能根据用户需求自动生成代码,降低开发门槛。文章详细说明了通过 CodeBuddy 创建 Vue 项目的步骤,包括解决项目创建失败的问题、自动补全代码功能以及启动开发服务器的方法。无论开发者经验如何,CodeBuddy 都能显著提升效率,让开发更专注创意实现。
|
9月前
|
人工智能 JavaScript 前端开发
Vue 性能革命:揭秘前端优化的终极技巧;Vue优化技巧,解决Vue项目卡顿问题
Vue在处理少量数据和有限dom的情况下技术已经非常成熟了,但现在随着AI时代的到来,海量数据场景会越来越多,Vue优化技巧也是必备技能。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
1053 14
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
348 0