debounce(过滤操作符)
目录
debounce很有意思的一个词,去抖,要明白debounce的用法首先要知道什么是“去抖”
1 debounce:去抖
当调用函数N秒后,才会执行函数中动作,若在这N
秒内又重复调用该函数则将取消前一次调用,并重新计算执行时间。
这个debounce在js常被使用,比如界面根据用户输入做ajax请求局部刷新页面,那么势必会重复请求接口,而实际可能在n秒内用户并没有完成输入,那么频繁调函数肯定是不准确的,那么可以设定一个debounce time,在n秒内的调用都是无效的。
2 throttle 节流
与之相对的是throttle,节流,网络上有个很形象的比喻:如果将水龙头拧紧直到水是以水滴的形式流出,那你会发现每隔一段时间,就会有一滴水流出。
也就是会说预先设定一个执行周期,当调用动作的时刻大于等于执行周期则执行该动作,然后进入下一个新周期。throttle会在后面分析。
3 debounce接口
<U> Flowable< |