Rxjs学习笔记四

过滤类操作符

  • filter

使用filter产生的Observable对象,产生数据的时机和上游一致,当上游产生数据的时候,只要这个数据满足判断条件,就会立刻被同步传给下游

  • first

first可有没有判定函数参数,当不给任何判定函数的时候,就相当于找上游Observable吐出的第一个数据

first的第二个参数就是一个结果选择参数,把代表满足上游的值和序号合并为一个数组,传递给下游

  • take

只支持一个参数count,就是限定拿上游Observable的数据数量

  • take和filter的组合

要想获得上游Observable满足条件的前N个数据,需要用上述操作符的组合

Rx.Observable.prototype.takeCountWhile=function(count,predicate){
    return this.filter(predicate).take(count)
​
}

var a=Rx.Observable.interval(1000)
a.takeCountWhile(5,(x=>x%2==0)).subscribe(x=>console.log(x))
  • skip

表示跳过前N个之后全拿,接受一个count参数,

  • skipWhile

跳过数据前面的满足判断条件的数据,跳过了这个之后后面就不再做跳过动作

  • throttleTime和debounceTime

这两个操作符名字包含Time,参数也就是代表毫秒数的时间。

throttleTime的作用是限制在duration时间范围内,从上游传递给下游数据的个数;debounceTime的作用是让传递给下游的数据间隔不能小于给定的时间dueTime。

我的理解是,debounceTime表示只有当下一个吐出的时间和这次的时间差大于参数指定的时间的时候,才会把这次的数据推送出去,同时最后一个数据也因此肯定会被推送出去;而throttleTime表示,在 把这次数据推送出去之后,在参数指定的时间间隔之内会忽略其产生的所有数据,过了时间间隔会再次把生成的数据推送出去。

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值