过滤类操作符
- 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表示,在 把这次数据推送出去之后,在参数指定的时间间隔之内会忽略其产生的所有数据,过了时间间隔会再次把生成的数据推送出去。