首页
学习
活动
专区
圈层
工具
发布
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

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

    Observable是一个集合了观察者模式、迭代器模式和函数式的库,提供了基于事件流的强大的异步处理能力,并且已在 Stage1草案中。...在 Observable中我们可以通过 switchMap操作符处理异步问题,一个异步搜索看起来会是这样: input$.pipe(switchMap(keyword => Observable.ajax...当然,我们可以根据实际需要选用 switchMap、 mergeMap、 concatMap、 exhaustMap等。 而对于时间轴的操作, Rxjs也有巨大优势。...action => { action$.next(action); // ... }; }; 通过这样的封装,redux-observable就能让我们把 Observable强大的事件描述和处理能力和...}), map(res => ({ type: 'ACTION_4', payload: res })) ); ReduxObservable使我们可以结合 Redux和

    1.6K20

    Android Jetpack系列 之LiveData

    通知TextView便于TextView重新显示,如果矬一点,可能会想到将View传递到ViewModel中,让ViewModel持有View的引用,这种方式确实可以实现需求,但是后患无穷,并且View和ViewModel...Main3ActivityViewModel(int count) { this.mCount.setValue(count); } } LiveData类型的变量我们通过set和get...程序达到了我们预期的结果,但是我们这里知道,对于学生这个属性来说,学号和姓名是不可变的,只有分数是可变的,所以这个时候我们可以使用map函数只对分数进行观察,改写ViewModel中的代码如下所示: public...在实际项目开发中我们使用switchMap的频率还是很高的,毕竟 只要LiveData对象是调用其他方法获取的 ,我们就可以这样做, 在点击事件中我们设置了可观察数据:分数,当分数改变的时候,就会执行switchMap...函数 ,switchMap会将获取的数据转换为可观察的LiveData,所以我们监听这个LiveData对象 就可以观察到数据的变化了。

    1.3K20

    RxJava2 实战知识梳理(3) - 优化搜索联想功能

    如果用户依次输入了ab和abc,那么首先会发起关键词为ab请求,之后再发起abc的请求,但是abc的请求如果先于ab的请求返回,那么就会造成用户期望搜索的结果为abc,最终展现的结果却是和ab关联的。...使用switchMap操作符,这样当发起了abc的请求之后,即使ab的结果返回了,也不会发送给下游,从而避免了出现前面介绍的搜索词和联想结果不匹配的问题。...test(String s) throws Exception { return s.length() > 0; } }).switchMap...2.3 switchMap ?...switchMap的原理是将上游的事件转换成一个或多个新的Observable,但是有一点很重要,就是如果在该节点收到一个新的事件之后,那么如果之前收到的时间所产生的Observable还没有发送事件给下游

    1.1K70

    构建流式应用:RxJS 详解

    RxJS 是基于观察者模式和迭代器模式以函数式编程思维来实现的。 观察者模式 观察者模式在 Web 中最常见的应该是 DOM 事件的监听和触发。...operators 具有静态(static)方法和实例( instance)方法,下面使用 Rx.Observable.xx 和 Rx.Observable.prototype.xx 来简单区分,举几个例子...Rx.Observable.prototype.switchMap switchMap 与 mergeMap 都是将分支流疏通到主干上,而不同的地方在于 switchMap 只会保留最后的流,而取消抛弃之前的流...除了上面提到的 marbles,也可以 ASCII 字符的方式来绘制可视化图表,下面将结合 Map、mergeMap 和 switchMap 进行对比来理解。...switchMap 中,A 和 B 是主干上产生的流,a1、a2 为 A 在分支上产生,b1、b2 为 B 在分支上产生,可看到,最终将归并到主干上。

    8.5K31

    RxJava2 实战知识梳理(3) - 优化搜索联想功能

    如果用户依次输入了ab和abc,那么首先会发起关键词为ab请求,之后再发起abc的请求,但是abc的请求如果先于ab的请求返回,那么就会造成用户期望搜索的结果为abc,最终展现的结果却是和ab关联的。...使用switchMap操作符,这样当发起了abc的请求之后,即使ab的结果返回了,也不会发送给下游,从而避免了出现前面介绍的搜索词和联想结果不匹配的问题。...throws Exception { return s.length() > 0; } }).switchMap...2.3 switchMap ?...switchMap的原理是将上游的事件转换成一个或多个新的Observable,但是有一点很重要,就是如果在该节点收到一个新的事件之后,那么如果之前收到的时间所产生的Observable还没有发送事件给下游

    57710
    领券