首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Ngxs存储快照与选定快照

Ngxs存储快照与选定快照
EN

Stack Overflow用户
提问于 2020-05-19 10:10:29
回答 2查看 961关注 0票数 0

Ngxs Store中的快照和选择快照有什么不同?

我知道如何使用快照,它会获取当前状态值。

this.oriFormData = this.store.snapshot();

因此,当重置时,我像这样重置商店

this.store.reset(this.oriFormData);

是否可以使用selectsnapshot方法来选择一个/多个状态,而不是使用快照来获取整个应用程序的状态?

EN

回答 2

Stack Overflow用户

发布于 2020-05-23 19:03:32

你有没有考虑过使用选择器,@Select()

代码语言:javascript
复制
@Select(ZooState.pandas) pandas$: Observable<string[]>;
@Select(FoodState.leafs) leafs$: Observable<string[]>;

然后使用一些rxjs魔法

代码语言:javascript
复制
let pandasAndLeafs;
[pandas$, leafs$].pipe(combineAll()).subscribe(dinner => (pandasAndLeafs = dinner));
console.log(pandasAndLeafs);
票数 2
EN

Stack Overflow用户

发布于 2020-05-19 11:00:17

是的,您可以使用selectSnapshot来获取特定状态的当前状态值,所使用的语法与从存储中执行常规select时使用的语法相同。

例如。

store.selectSnapshot(MyState)store.selectSnapshot(state => state.myState)

传递静态选择器也是有效的,例如store.selectSnapshot(MyState.mySelector)

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

https://stackoverflow.com/questions/61882087

复制
相关文章

相似问题

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