首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

浅谈前端响应式设计(二)

在 Observable中我们可以通过 switchMap操作符处理异步问题,一个异步搜索看起来会是这样: input$.pipe(switchMap(keyword => Observable.ajax...而要聚合多个数据源并做异步处理时: combineLatest(foo$, bar$).pipe( switchMap(keyword => fromPromise(someAsyncOperation...switchMap当上游有新值到来时,会忽略结束已有未完成的 Observable然后调用函数返回一个新的 Observable,我们只使用一个函数就解决了并发安全问题。...当然,我们可以根据实际需要选用 switchMap、 mergeMap、 concatMap、 exhaustMap等。 而对于时间轴的操作, Rxjs也有巨大优势。...我们可以非常方便地根据 Action去处理副作用: action$.pipe( ofType('ACTION_1'), switchMap(() => { // ... }),

1.1K20

一篇掌握LiveData transformations

这个类提供了三个静态方法:map、switchMap和distinctUntilChanged,这些方法将在下面解释。...switchMap的转换可能有点棘手,所以让我们从一个简单的例子开始。我们想为Player实现一个基本的搜索功能。每次搜索文本发生变化时,我们都想更新搜索结果。下面的代码显示了它是如何工作的。...MediatorLiveData类是我在处理LiveData时使用最多的类(尽管我在有意义的时候使用map / switchMap / distinctUntilChanged)。...结论 在所有的LiveData转换中使用map、switchMap和distinctUntilChanged。除非有必要,否则应避免编写自己的转换,并尝试结合操作来创建更复杂的转换。...如果你发现自己在地图/switchMap内或观察块内使用.value属性获得另一个LiveData的当前值,你应该考虑创建一个MediatorLiveData来正确合并来源。

1.4K20

Android Jetpack系列 之LiveData

onChanged(Integer integer) { tvScore.setText("分数:" + integer); } }); 运行结果与上面一致,这就是map转换函数的用法 switchMap...score = new MutableLiveData(); public void setScore(int score) { this.score.setValue(score); } 使用switchMap...将信息转化为可观察的LiveData对象: private LiveData studentLiveData = Transformations.switchMap(score, new...在实际项目开发中我们使用switchMap的频率还是很高的,毕竟 只要LiveData对象是调用其他方法获取的 ,我们就可以这样做, 在点击事件中我们设置了可观察数据:分数,当分数改变的时候,就会执行switchMap...函数 ,switchMap会将获取的数据转换为可观察的LiveData,所以我们监听这个LiveData对象 就可以观察到数据的变化了。

1.1K20

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券