- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我似乎无法弄清楚问题是什么,
我有一个服务有这样一个行为主题......
popupSource = new BehaviorSubject<any>('');
popup(component) {
this.popupSource.next(component);
}
然后在我的头部组件中
popupClick() {
this._service.popup('example');
}
然后在我的 header.html 中
<button (click)="popupClick()"></button>
然后在我的应用程序组件中
ngOnInit() {
this._service.popupSource.subscribe((result) => {
console.log(result);
})
}
所以发生的事情是点击触发了 this._service.popup('example');
但它从未点击订阅...
我在每个函数上都设置了断点,它成功到达了 this.popupSource.next(component)
但之后什么都没有?每次单击按钮时,我都应该获取控制台日志。
我不确定我做错了什么...为了简洁起见,我省略了代码,所以如果您需要更多信息,请告诉我
编辑
我也试过
private popupSource = new BehaviorSubject<any>('');
getPopup = this.popupSource.asObservable();
popup(component) {
this.popupSource.next(component);
}
并且在我的应用程序组件中改为监听 getPopup
ngOnInit() {
this._service.getPopup.subscribe((result) => {
console.log(result);
})
}
那也不管用,我不知道是什么问题...
谢谢
最佳答案
这里的问题是您在两个不同的模块中提供服务,最终有两个服务实例。如果您使用 Angular v6,最简单的方法是在您的服务中使用 providedIn 标志:
import { Injectable } from '@angular/core';
@Injectable({providedIn: 'root'})
class myService {}
通过这种方式,您无需在任何模块的 providers 数组中提供您的服务,它会自动在根注入(inject)器中提供。
关于此的文档可以在这里找到:Angular providers .
如果您使用的是 Angular v5,您应该只在您的 AppModule 中提供您的服务。
关于javascript - BehaviorSubject 不工作 Angular 5,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50867132/
我有一个 rxjs@6 BehaviorSubject source$ ,我想从 source$ 获取子值 const source$ = new BehaviorSubject(someValu
场景我有一个 Territories 列表,我想从服务器获取每个 Territory 中的所有 Items。因此,我决定使用 BehaviorSubject 来尝试一下。我不知道我是不是“疯了”。这就
至少在移动应用程序中,BehaviorSubject 被频繁使用,为属性建模——它有一个当前值,可以随时查询并观察。 有时它只想转换 BehaviorSubject 而无需订阅它。例如。如果有类,它充
我在使用 Angular 服务时遇到了一个由 BehaviorSubject 引起的错误。 错误 Module '"ng5/node_modules/rxjs/BehaviorSubject"' ha
我正在使用 Angular 2 和 RxJS 5。 这两者有什么区别吗: 应该首先使用哪个?谢谢 isOpen$ = new BehaviorSubject(true); 和 isOpen$ = Be
我正在查看可观察对象的接口(interface),发现您可以将实现 PartialObserver 的任何内容传递给订阅函数。所以我用 BehaviorSubject 做到了。 像这样(一) sour
我的其中一个组件中有这个: public booleanSubject: BehaviorSubject = new BehaviorSubject(false); 当我添加 "strictFunct
您好,我有一个具有简单类型 int 的 BehaviorSubject,我将值 5 添加到它,然后添加另一个值 5。流监听器向我发送了两个事件。如果值等于最后一个值,如何强制检查值并且不发送事件。示例
在我们的单页应用程序中,我们开发了一个集中式存储类,该类使用 RxJS 行为主体来处理应用程序的状态及其所有变化。我们应用程序中的几个组件正在订阅我们商店的行为主题,以便接收对当前应用程序状态的任何更
我有一个 Angular 服务,它有一个名为 must_checkout 的 bool 属性。我的服务还包含一个名为 observable_must_checkout 的属性,它是一个调查 must_
我有一个 BehaviorSubject我希望能够filter ,但要保持新订阅者在订阅时始终获得一个值的行为主题式质量,即使最后发出的值被过滤掉。有没有一种简洁的方法可以使用 rxjs 的内置函数来
我有一个 BehaviorSubject我想重置 - 我的意思是我希望最新的值不可用,就像它刚刚创建一样。 我似乎没有看到可以执行此操作的 API,但我想还有另一种方法可以实现相同的结果吗? 我想要的
我使用 RxJS 中的 BehaviourSubject: private rights = new BehaviorSubject>([]); updateRights(rights: Array)
我几乎已经完成了 android,但对 java 8 还是陌生的。我制作了一个 BehaviourSubject>。 我在上面放置了一个可观察对象。在 Presenter 类中,我将 Behaviou
在我的 Angular 应用程序中 我多次尝试使用 BehaviorSubject 获取值,以了解值何时更改或接收。我无法在加载组件之前获取值。 通过此链接,您可以查看返回的内容: https://d
我有一个函数应该返回一个BehaviorSubject。该主题旨在返回 Profile 的最新版本 (user)Profile 只是一个包含对三个成员的引用的 POJO: - 用户, - 该用户的 M
通缉行为: subject = BehaviorSubject.create(1); subject.subscribe(number -> print(number), error -> print
我是 RxJava 的新手,我选择使用它是因为我认为它非常适合我的用例。 我有一些 Integer 值,我想在无限的时间段内观察。每当这些值之一发生变化(即一个事件)时,我希望在另一个线程上调用它的所
我有一个 EvaluateHistoryItem[] 类型的 BehaviourSubject history$。在 uploadFile 方法中,我用逗号分割上传的 .txt 文件,然后将它们推送到
我是 Angular 的新手,不知道如何使用异步调用来更新响应式表单。 我有一个基于对象模型的 react 形式。表单中的任何更改都会触发 HTTP 请求,该请求可能会发回对象的更新版本作为响应。我需
我是一名优秀的程序员,十分优秀!