[RxJS] Filtering operators: distinct and distinctUntilChanged
Operator distinct() and its variants are an important type of Filtering operator. This lessons shows how they work and in what cases are they useful.
distinctUntilChanged():
var foo = Rx.Observable.interval(500).take(5) .zip(Rx.Observable.of('a','b','a','a','b'), (x,y)=>y); /* --a--b--a--a--b| distinctUntilChanged --a--b--a-----b| */ var result = foo.distinctUntilChanged(); result.subscribe( function (x) { console.log('next ' + x); }, function (err) { console.log('error ' + err); }, function () { console.log('done'); }, );
distinct(comparFn, flushFn):
var foo = Rx.Observable.interval(500).take(5) .zip(Rx.Observable.of('a','b','a','a','b'), (x,y)=>y); /* --a--b--a--a--b| distinct --a--b---------| */ var result = foo.distinct(); result.subscribe( function (x) { console.log('next ' + x); }, function (err) { console.log('error ' + err); }, function () { console.log('done'); }, ); /* "next a" "next b" "done" */
With CamperFn():
var foo = Rx.Observable.interval(500).take(5) .zip(Rx.Observable.of('a','b','a','A','b'), (x,y)=>y); var comparFn = (x, y) => { return x.toLowerCase() === y.toLowerCase(); } /* --a--b--a--A--b| distinct --a--b---------| */ var result = foo.distinct(comparFn); result.subscribe( function (x) { console.log('next ' + x); }, function (err) { console.log('error ' + err); }, function () { console.log('done'); }, ); /* "next a" "next b" "done" */
with FlusherFn:
var foo = Rx.Observable.interval(500).take(5) .zip(Rx.Observable.of('a','b','a','A','b'), (x,y)=>y); var comparFn = (x, y) => { return x.toLowerCase() === y.toLowerCase(); } var flushFn = Rx.Observable.interval(1100).take(1) .concat(Rx.Observable.never()); /* --a--b--a--A--b|
-------0-------- distinct(comparFn, flushFn) --a--b--a-----b| */ var result = foo.distinct(comparFn, flushFn); result.subscribe( function (x) { console.log('next ' + x); }, function (err) { console.log('error ' + err); }, function () { console.log('done'); }, ); /* "next a" "next b" "next a" "next b" "done" */
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具
2013-05-30 【Javascript】类,封装性 -- 1