首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >值更改为false时未通知观察者

值更改为false时未通知观察者
EN

Stack Overflow用户
提问于 2018-08-23 10:00:01
回答 1查看 158关注 0票数 0

我正在尝试Angular和rxjs (6.0),但遇到了一个问题。

它开始了,

这是我的样例代码库:https://stackblitz.com/edit/angular-kxqj8d?file=app%2Finput-overview-example.ts

代码语言:javascript
运行
复制
var service = {
  isUserSignedIn: null
};
var myObservable$ = new BehaviorSubject(service);

setInterval(function() {
  debugger;
  service.isUserSignedIn = !service.isUserSignedIn;
  service = JSON.parse(JSON.stringify(service));
  console.log("--------------------------------------------")
  console.log("Value update to : " + service.isUserSignedIn)
  myObservable$.next(service);


}.bind(this), 5000);


myObservable$
  .pipe(
  filter((curr) => curr.isUserSignedIn != null),
  distinctUntilChanged((prev, curr) => {
    debugger;
    console.log("Value during comparison prev: " + prev.isUserSignedIn + " curr: " + curr.isUserSignedIn)
    return prev.isUserSignedIn === curr.isUserSignedIn;
  }))
  .subscribe(value => {
    console.log("Got Notified! New Value: " + value.isUserSignedIn);
  })

以下是控制台日志:

在"distinctUntilChanged“操作符中,当标志"service.isUserSignedIn”设置为false时,prev和curr的值是相同的。但是,当相同的标志设置为true时,它才能正常工作!

正因为如此,观察者没有得到通知!

我花了两天时间试图弄清楚,但找不到哪里出了问题。

你们能帮帮我吗。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-23 11:13:56

您需要将JSON.parse(JSON.stringify(service))的结果赋给一个新变量,并将其传递给next。如果您不这样做,那么您将覆盖以前的service值,实际上违背了使用JSON parse/stringify创建副本的目的。

Updated Stackblitz

旁注

考虑下面这段更简洁的代码:

代码语言:javascript
运行
复制
interval(5000).pipe(
  map(() => {
    service.isUserSignedIn = !service.isUserSignedIn;
    return JSON.parse(JSON.stringify(service));
  }),
  distinctUntilChanged((prev, curr) => {
    console.log(prev.isUserSignedIn, curr.isUserSignedIn)
    return prev.isUserSignedIn === curr.isUserSignedIn;
  })
)
.subscribe(value => {
  console.log(`Result: ${value.isUserSignedIn}`)
});
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/51977371

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档