如何清除Angular 2中的“不同”RxJS运算符?

时间:2017-07-08 04:52:20

标签: angular rxjs angular2-observables

有没有办法清除distinct()缓存?

正如你所看到的,有时我设置this.messages = [],此时,我想清除缓存。相反,我做了一个黑客,我增加distinctCount。

ngOnInit() {
    let saved = {}
    let distinctCount = 1000000000000
    let messageStream = this.route.params
            .map(params=>params['id'])
            .switchMap((id)=> {
                this.messages = []
                saved[this.id] = this.newMessage
                this.id = id
                distinctCount+=1000000000000
                this.newMessage = saved[id] || ''
                return Observable.interval(3500).startWith(0).switchMap(()=> {
                    let count = 5
                    if (this.messages.length == 0) {
                        count = 10
                    }
                    return this.conversationsApi.apiConversationsByConversationIdGetMessagesGet(this.id, this.authService.getAuth(), undefined, count, undefined, undefined, undefined)
                })
            })
            .concatMap((messages:Array<MessageModel>)=>{
                return Observable.from(messages.slice().reverse())
            })
            .distinct(message=>message.id+distinctCount)
}

1 个答案:

答案 0 :(得分:3)

最终得到了一个很好的解决方案,只需将this.route.params observable作为distinct()的第二个参数传递。

第二个参数是一个flush observable,只要该observable发出,就会刷新其缓存

因此,只要用户在会话之间导航,缓存就会刷新。

C.COM