安卓Jetpack进阶——map与switchMap(一)

简介: 之前的文章中我们了解了Jetpack组件中ViewModel,LiveData与Lifecycle,在工作中,我已经明明白白的知道了他们的作用,我现在写的每个页面几乎都少不了它们

前言

之前的文章中我们了解了Jetpack组件中ViewModel,LiveData与Lifecycle,在工作中,我已经明明白白的知道了他们的作用,我现在写的每个页面几乎都少不了它们,当然,这也就避免不了我继续深入下去的心,于是我在官网又发现了Jetpack组件LiveData的两个好伙伴-map与switchMap。


网络异常,图片无法展示
|
网络异常,图片无法展示
|


可惜官网不够人性化,这部分的中文资料还是没有完善,不过我已经花费一段时间去阅读,下面就让我们看看它们庐山真面目。

正篇

出现背景与使用场景

在公司开发,大多数时候的项目还是比较复杂的,于是就会出现很多特殊的需求,而且代码也会讲究许多,也就是这个原因,LiveData为了去适应各种不同的需求场景,出现了两种转换方法:map()和switchMap()。 首先,让我们看看map():

map()方法的使用

使用方法的说明,我们就先举一个例子,假设你有了一个用户类Uer类,这个类包含用户姓名与年龄:

data class User(var firstName : String, var lastName : String, var age : Int)

于是我们可以在ViewModel中创建一个相应的LiveData去包含User类型数据:

class MainViewModel(countReserved: Int) : ViewModel() {
    val userLiveData = MutableLiveData<User>()
    ...
}

这时就有问题了,如果在Activity中这就会将整个User类型的LiveData暴露给外部,需求要是说年龄是隐私,不能泄露,我们明确只要用户姓名,这种情形下就是非常糟糕的了,而map()方法就是解决这个问题的:

class MainViewModel(countReserved: Int) : ViewModel() {
    private val userLiveData = MutableLiveData<User>()
    val userName : LiveData<String> = Transformations.map(userLiveData) { user ->
        "${user.firstName} ${user.lastName}"
    }
    ...
 }

这里代码说明了map()方法的作用就是将实际包含数据的LiveData和仅用于观察数据的LiveData进行转换。

上面的代码中需要用户的名称,于是我们调用了Transformations的map()方法去对LiveData数据类型进行转换,这个方法接受了两个参数,第一个是原始LiveData对象,第二个则是转换函数;


网络异常,图片无法展示
|


而我们需要在转换函数里编写具体的转换逻辑,而上述代码中转换逻辑也是十分简单的,即将User对象转换称一个只包含用户名称的字符串。


网络异常,图片无法展示
|


此外,为了保证数据的封装性,我们将userLiveData声明成private,这样在外部使用只要观察userName这个LiveData即可。


网络异常,图片无法展示
|


而当userLiveData数据发生变化时,map()方法会监听到变化而去执行转换函数中的逻辑,接着再将转换之后的数据告知userName观察者。

这样一套下来,我们的map()的工作就完成了,为了防止因为Konltin表达过于简单,导致我们认为转换逻辑方法比较难,我们再看看Java的写法:


网络异常,图片无法展示
|


源码也是十分清晰的:


网络异常,图片无法展示
|


仅仅就是返回你想要的类型即可。

结语

现在我们对map()方法有了一定的认知了,接下来,我们会去探究switchMap()方法,然后将二者结合使用再应用到我们的实例上演示一番,感谢您的观看!

相关文章
|
3月前
|
安全 Java Android开发
安卓开发中的新趋势:Kotlin与Jetpack的完美结合
【6月更文挑战第20天】在不断进化的移动应用开发领域,Android平台以其开放性和灵活性赢得了全球开发者的青睐。然而,随着技术的迭代,传统Java语言在Android开发中逐渐显露出局限性。Kotlin,一种现代的静态类型编程语言,以其简洁、安全和高效的特性成为了Android开发中的新宠。同时,Jetpack作为一套支持库、工具和指南,旨在帮助开发者更快地打造优秀的Android应用。本文将探讨Kotlin与Jetpack如何共同推动Android开发进入一个新的时代,以及这对开发者意味着什么。
|
3月前
|
存储 JavaScript 前端开发
JavaScript进阶-Map与Set集合
【6月更文挑战第20天】JavaScript的ES6引入了`Map`和`Set`,它们是高效处理集合数据的工具。`Map`允许任何类型的键,提供唯一键值对;`Set`存储唯一值。使用`Map`时,注意键可以非字符串,用`has`检查键存在。`Set`常用于数组去重,如`[...new Set(array)]`。了解它们的高级应用,如结构转换和高效查询,能提升代码质量。别忘了`WeakMap`用于弱引用键,防止内存泄漏。实践使用以加深理解。
58 3
|
3天前
|
安全 Java Android开发
探索安卓应用开发的新趋势:Kotlin和Jetpack Compose
在安卓应用开发领域,随着技术的不断进步,新的编程语言和框架层出不穷。Kotlin作为一种现代的编程语言,因其简洁性和高效性正逐渐取代Java成为安卓开发的首选语言。同时,Jetpack Compose作为一个新的UI工具包,提供了一种声明式的UI设计方法,使得界面编写更加直观和灵活。本文将深入探讨Kotlin和Jetpack Compose的特点、优势以及如何结合使用它们来构建现代化的安卓应用。
13 4
|
2月前
|
存储 数据库 Android开发
🔥Android Jetpack全解析!拥抱Google官方库,让你的开发之旅更加顺畅无阻!🚀
【7月更文挑战第28天】在Android开发中追求高效稳定的路径?Android Jetpack作为Google官方库集合,是你的理想选择。它包含多个独立又协同工作的库,覆盖UI到安全性等多个领域,旨在减少样板代码,提高开发效率与应用质量。Jetpack核心组件如LiveData、ViewModel、Room等简化了数据绑定、状态保存及数据库操作。引入Jetpack只需在`build.gradle`中添加依赖。例如,使用Room进行数据库操作变得异常简单,从定义实体到实现CRUD操作,一切尽在掌握之中。拥抱Jetpack,提升开发效率,构建高质量应用!
49 4
|
2月前
|
存储 移动开发 Android开发
使用kotlin Jetpack Compose框架开发安卓app, webview中h5如何访问手机存储上传文件
在Kotlin和Jetpack Compose中,集成WebView以支持HTML5页面访问手机存储及上传音频文件涉及关键步骤:1) 添加`READ_EXTERNAL_STORAGE`和`WRITE_EXTERNAL_STORAGE`权限,考虑Android 11的分区存储;2) 配置WebView允许JavaScript和文件访问,启用`javaScriptEnabled`、`allowFileAccess`等设置;3) HTML5页面使用`<input type="file">`让用户选择文件,利用File API;
|
3月前
|
安全 JavaScript 前端开发
kotlin开发安卓app,JetPack Compose框架,给webview新增一个按钮,点击刷新网页
在Kotlin中开发Android应用,使用Jetpack Compose框架时,可以通过添加一个按钮到TopAppBar来实现WebView页面的刷新功能。按钮位于右上角,点击后调用`webViewState?.reload()`来刷新网页内容。以下是代码摘要:
|
3月前
|
JavaScript Java Android开发
kotlin安卓在Jetpack Compose 框架下跨组件通讯EventBus
**EventBus** 是一个Android事件总线库,简化组件间通信。要使用它,首先在Gradle中添加依赖`implementation &#39;org.greenrobot:eventbus:3.3.1&#39;`。然后,可选地定义事件类如`MessageEvent`。在活动或Fragment的`onCreate`中注册订阅者,在`onDestroy`中反注册。通过`@Subscribe`注解方法处理事件,如`onMessageEvent`。发送事件使用`EventBus.getDefault().post()`。
|
3月前
|
JavaScript 前端开发 Android开发
kotlin安卓在Jetpack Compose 框架下使用webview , 网页中的JavaScript代码如何与native交互
在Jetpack Compose中使用Kotlin创建Webview组件,设置JavaScript交互:`@Composable`函数`ComposableWebView`加载网页并启用JavaScript。通过`addJavascriptInterface`添加`WebAppInterface`类,允许JavaScript调用Android方法如播放音频。当页面加载完成时,执行`onWebViewReady`回调。
|
3月前
|
Android开发
Jetpack Compose: Hello Android
Jetpack Compose: Hello Android
|
3月前
|
安全 网络安全 API
kotlin安卓开发JetPack Compose 如何使用webview 打开网页时给webview注入cookie
在Jetpack Compose中使用WebView需借助AndroidView。要注入Cookie,首先在`build.gradle`添加WebView依赖,如`androidx.webkit:webkit:1.4.0`。接着创建自定义`ComposableWebView`,通过`CookieManager`设置接受第三方Cookie并注入Cookie字符串。最后在Compose界面使用这个自定义组件加载URL。注意Android 9及以上版本可能需要在网络安全配置中允许第三方Cookie。