13、RxJS 中的时间与缓冲操作

RxJS 中的时间与缓冲操作

1. RxJS 时间操作的引入

在处理用户输入时,我们可以利用 RxJS 来优化操作。例如,在搜索功能中,为了避免频繁的请求,可以使用 debounceTime 操作符。

以下是一个简单的防抖优化搜索程序:

const notEmpty = input => !!input && input.trim().length > 0;
const sendRequest = function(arr, query) {
  return arr.filter(item => {
    return query.length > 0 && item.startsWith(query); 
  });
}
const search$ = Rx.Observable.fromEvent(searchBox, 'keyup')
  .debounceTime(1000)  
  .pluck('target', 'value') 
  .filter(notEmpty)
  .do(query => console.log(`Querying for ${query}...`))
  .map(query =>
    sendRequest(testData, query))
  .subscribe(result => { 
    if(result.length === 0) {
      clearResults(results);
    }   
    else {
   
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值