假设在一个实现了 viewmodel 的类里面有如下代码:
private val queryLiveData = MutableLiveData<String>()
private val repoResult: LiveData<RepoSearchResult> = Transformations.map(queryLiveData) {
repository.search(it)
}
val repos: LiveData<List<Repo>> = Transformations.switchMap(repoResult) {
it.data
}
fun searchRepo(queryString: String) {
queryLiveData.postValue(queryString)
}
如上代码演示了 Transformations map 的应用。如果调用 searchRepo 方法,queryLiveData 会给订阅了它的 observer 发送通知,可是这里的代码并没有显示的 observer 订阅,当然这个操作还是存在的,只是 map 函数帮我们操作了。如上调用的 map 函数我们传入了 queryLiveData 这个 LiveData 以及一个 Function 代码 块,只不过是上面的 map 函数使用了 lambda 的简写,将代码块卸载了括号外面。看下 map 代码的实现:
@MainThread
@NonNull
public static <X, Y> LiveData<Y> map(
@NonNull LiveData<X> source,
@NonNull final Function<X, Y> mapFunction)

本文详细介绍了 Android LiveData 的 Transformations 中的 map 和 switchMap 的工作原理和区别。通过代码示例展示了如何使用它们,并解释了为何在特定场景下选择 switchMap 而不是 map,主要关注它们在数据流更新和响应中的行为差异。
最低0.47元/天 解锁文章
1003

被折叠的 条评论
为什么被折叠?



