4

我想为我的注册做这样的事情。

单击注册按钮时,将执行以下操作:

this.store.dispatch(new Register(user))
    .subscribe(response => {
      localStorage.setItem('token', JSON.stringify(response.token));
      let redirectUrl = this.store.dispatch(new RegisterSuccess(response));

      if (redirectUrl) {
        this.router.navigate([redirectUrl]);
      } else {
        this.router.navigate(['/home']);
      }
    }, error => {
      this.store.dispatch(new RegisterFailed());
    });

状态:

  @Action(Register)
  register({ patchState }: StateContext<AuthenticationStateModel>, { payload }: Register) {
    patchState({
      isLoading: true
    });

    return this.authenticationService.register(payload);
  }

  @Action(RegisterFailed)
  registerFailed({ patchState }: StateContext<AuthenticationStateModel>) {
    patchState({
      isLoading: false
    });
  }

  @Action(RegisterSuccess)
  registerSuccess(sc: StateContext<AuthenticationStateModel>, { payload }: RegisterSuccess) {
    sc.patchState({
      user: payload.user,
      token: payload.token,
      isAuthenticated: true,
      isLoading: false,
    });

    return sc.getState().redirectUrl;
  }

1) 我希望注册操作从 http 请求返回 Observable。
2)然后订阅它,如果请求成功,则触发RegisterSuccess(我希望它从状态返回一个项目)。如果请求失败,则触发 RegisterFailed。

实际上,我已经通过将相同的代码放入 state 中来完成它(对 c 的修改很少),但我觉得它太乱了,而且不是正确的方法,所以把它放在组件中,但我不能让它再次工作.

4

3 回答 3

11

文档建议您执行以下操作:

对于同步操作:

return ctx.dispatch(new TakeAnimalsOutside());

对于异步操作:

return this.animalService.feed(action.animalsToFeed).pipe( ... mergeMap(() => ctx.dispatch(new TakeAnimalsOutside()))

有趣的dispatch是你可以做到 dispatch([new Action1(), new Action2(), ...etc])

于 2018-11-15T03:27:50.430 回答
3

这就是我的做法:

  • 当用户执行一个动作时,只需发送动作参数(如果有的话),例如new MyAction(). 通常,不需要订阅这个分派的动作,我发现它也使代码看起来很混乱。
  • @Action函数处理内容并可选地分派成功/失败的动作(例如MyActionSuccess,,MyActionFailed或其他一些有意义的动作)。如果这个动作只能有一个结果,那么不要费心发送一个成功 - 这个动作的完成就是成功。
  • 为了处理操作的成功(等等)执行,我订阅了用于路由/重定向的操作处理程序。这些将由组件根据组件的生命周期订阅/取消订阅。(例如ngOnInit()ngOnDestroy())。

老实说,我不知道这是正确的还是最好的方法,我现在是怎么做的。

于 2018-06-08T00:08:12.247 回答
0

你可以使用concatMap它是rxjs运算符

example.pipe(
      concatMap(() => this.store.dispatch(new FirstAction())),
      concatMap(() => this.store.dispatch(new SecondAction())),
      concatMap(() => this.selectorDependOnAction$)).subscribe((res) => {
        //anything you want to do it
      });
  }

一些资源concatMap

于 2021-11-29T18:40:57.403 回答