首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >NGXS状态不变

NGXS状态不变
EN

Stack Overflow用户
提问于 2018-08-27 03:20:03
回答 1查看 1.5K关注 0票数 5

可能有人知道为什么HttpClient POST请求中的NGXS状态不能改变。

代码语言:javascript
复制
ctx.patchState()

仅在HTTP POST请求之外起作用。

代码语言:javascript
复制
    @Action(SignIn)
    signin(ctx: StateContext<AppStateModel>, { payload }: SignIn) {

        // ctx.patchState({isLoggedIn:true}) this works!

        return this.api$.signin(payload)
            .pipe(
                tap((user: User) => {
                    console.log(user);
                    ctx.patchState({ isLoggedIn: true })

                })
            )
            .subscribe(
                (user: User) => {
                    ctx.patchState({ isLoggedIn: true })

                }
            )
    }

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-08-27 04:23:46

实际上,状态正在改变,但您看不到它,因为您返回了尚未完成的订阅。换句话说,一旦返回的observable的订阅完成,您将看到操作被分派。

正如评论中提到的,返回的操作的可观察性是在幕后订阅的,所以没有必要再次订阅它。

说完之后,您可以在管道中传递take(1)

它所做的是,在触发一次之后完成对可观察对象的订阅。

代码语言:javascript
复制
    @Action(SignIn)
    signin(ctx: StateContext<AppStateModel>, { payload }: SignIn) {
        return this.api$.signin(payload)
            .pipe(
                take(1), // <-- Add that
                tap((user: User) => ctx.patchState({ isLoggedIn: true }))
            );
    }

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/52029547

复制
相关文章

相似问题

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