-2

我的服务中有一个名为refreshSubject$的主题。

  private refreshUsers$ = new Subject<User[]>();

每次添加用户时,他都会发出一个新值。

  saveUser(user: User[]) {
    return this.http.post<User>(this.url, user)
      .pipe(
        tap(() => {
          this.refreshUsers$.next();
        })
      );
  }

我在我的服务上使用 get 方法来检索值

  get refresh$() {
    return this.refreshUsers$;
  }

现在每次我添加一个新用户时,我都会使用next()方法发出一个新值。

  this.refreshUsers$.next();

在我的组件内部,我有我的生命周期钩子 ngOnInit,每次refreshUsers$主题发出新值时都会调用他。

  ngOnInit(): void {
    this.apiService.refresh$.subscribe(() => {
      this.getAllUsers();
    });
  }

为什么每次订阅新值时都会调用 ngOnInit?

4

3 回答 3

3

在 onInit 中,您订阅了您的主题,因此每次您发出新值时,都会运行方法“this.getAllUsers()”。您是否订阅了 OnInit 并不重要。在您取消订阅之前,订阅是有效的。

于 2020-02-29T11:10:09.247 回答
2

每次发出事件时,订阅都会触发,无论它位于何处。因此,您的 ngOnIt不会在每次触发事件时都被触发,而是“订阅”,但由于您的订阅在“ngOnInIt”内部,因此看起来“ngOnInIt”正在被触发。如果您不希望这样做,您可以将您的订阅移出 ngOnInIt,尽管它不会产生问题。因为您在 ngOnInIt 中编写的其他逻辑不会被触发。

如果你想自己检查,你可以在你的 ngOnInit 中添加一个 console.log("testing") ,但在订阅之外。并发出多个事件,我们会注意到“测试”只会记录一次(当组件加载时)

于 2020-02-29T11:21:33.050 回答
1

不是......每次发出值时都会调用订阅回调,即这部分:

() => {
      this.getAllUsers();
}

但是,您并不是每次发出值时都进行新订阅。

这就是可观察对象的工作方式

于 2020-02-29T11:06:41.560 回答