- 使用 selector 从 SAP Spartacus stat
- 如何安装指定版本的 SAP Spartacus
- 如何检测 SAP 电商云 Spartacus UI 当前正处于导
- SAP Commerce Accelerator和SAP Spa
- SAP UI5 sap.ui.vk 命名空间内的控件介绍
- 让 fork 出来的 Github 仓库从远端仓库拖取最新的修改
- SAP Spartacus Definition of Done
- 借助 SAP 电商云 Spartacus UI 提供的 Sche
- SAP 电商云 Spartacus UI 产品搜索结果的设计明细
- SAP Spartacus的Component映射
选择器 selector 是用于获取存储状态 state 切片的纯函数。
@ngrx/store 提供了一些帮助函数来优化这个选择。 选择器在选择状态切片时提供了许多功能。
使用 createSelector 和 createFeatureSelector 函数时,@ngrx/store 会跟踪调用选择器函数的最新参数,在 ngrx-store.js 里完成。
因为选择器是纯函数,当参数匹配时可以返回最后一个结果,而无需重新调用选择器函数。这可以提供性能优势,特别是对于执行昂贵计算的选择器。这种做法被称为 memoization.
最佳实践:
设计一个 featureState 包含了具体的应用逻辑。使用 createSelector 工具函数创建 selector.
data:image/s3,"s3://crabby-images/2b06f/2b06f96d768ac6c8ab13f373f48e8d6f54bb5693" alt=""
Spartacus 里有类似设计:
data:image/s3,"s3://crabby-images/aa25c/aa25c677496f2146378696adb07d16ab17a8eac8" alt=""
看个例子:
export class AppModule {
constructor(private config: DebugConfig,
private actions$: Actions,
private cartService: ActiveCartService,
private store: Store<StateWithMultiCart>){
// console.log('Jerry config: ', this.config);
/*const action = this.actions$.pipe(
ofType(CartActions.LOAD_CART),
map((action: CartActions.LoadCart) => action.payload),
tap((data) => console.log('Jerry cart: ' , data)));
action.subscribe();
const action2 = this.actions$.pipe(
ofType(CartActions.LOAD_CART_SUCCESS),
map((action: CartActions.LoadCartSuccess) => action.payload),
tap((data) => console.log('Jerry cart SUCCESS: ' , data)));
action2.subscribe();*/
const action3 = this.actions$.pipe(
ofType(CartActions.LOAD_CART_SUCCESS),
map((action: CartActions.LoadCartsSuccess) => action.payload),
tap((data) => {
console.log('Jerry cart SUCCESS: ' , data);
this.store.pipe(select(MultiCartSelectors.getMultiCartEntities)).subscribe((value) => {
console.log('Jerry result from selector: ', value);
});
}));
action3.subscribe();
/*
const loading$ = this.cartService.getLoading();
loading$.subscribe((data) => console.log('Jerry cart loading? ', data));*/
}
}
运行时:
data:image/s3,"s3://crabby-images/60ef0/60ef0b604945e45a76246e6c007300ab5d6a0969" alt=""
第一层:entities
第二层:000001
第三层:error,loading,success,processesCount 和 value.
这个 state 的结构是在哪里定义的呢?
data:image/s3,"s3://crabby-images/8ec09/8ec0910f6ddc34d9b01801c592cdf70914fd3285" alt=""
在 feature 的 store 文件夹下。
data:image/s3,"s3://crabby-images/18d42/18d42b2422ab9155abe617e1d3fcf06dd4763a0e" alt=""
data:image/s3,"s3://crabby-images/e1914/e19147b95fd45ff7f866d09fe1b92b3bedf1ec28" alt=""
ProcessesLoaderState 提供了 processesCount 字段,它本身又是 LoaderState 类型:
data:image/s3,"s3://crabby-images/6d1fc/6d1fc4e5c5443457d1a8ffa52ac6189ea55894e6" alt=""
因此也具有了 loading, error, success 和 value 四个字段:
data:image/s3,"s3://crabby-images/6fb84/6fb846f0bf86cfe8c4ae908a87667791415ac7b8" alt=""
EntityState 接口,本身又提供了第一层的 entities 结构和第二层的 id 结构。
data:image/s3,"s3://crabby-images/df48b/df48b10b60ccdece288f115982583edcc7139d66" alt=""
在我写下面这段高亮代码的上下文里,Cart 肯定已经可用了,因为它是在 LOAD_CART_SUCCESS 的回调里执行的。
data:image/s3,"s3://crabby-images/9a686/9a6864174916ea584fb93b6c94431cc68c628af5" alt=""
单步调试:
先执行distinguished,再执行 map:
data:image/s3,"s3://crabby-images/fad5a/fad5a50c9fc45d5fe1e1143e64d5855f506daa51" alt=""
data:image/s3,"s3://crabby-images/bf7c3/bf7c32f6797bb3559acfc88dfc50f0c129bbacb4" alt=""
data:image/s3,"s3://crabby-images/33071/33071c3a4b044705da17f13b88e78f799af0a86a" alt=""
value 包含了所有的 state 数据:
data:image/s3,"s3://crabby-images/e2e90/e2e90c737f828931d40a44653b5212b4dde701f0" alt=""
直接从内存里返回上一次的 result:
data:image/s3,"s3://crabby-images/2daca/2dacafd4679ef5ba1d9f925f69b563362d0b1a42" alt=""
强行在调试器里把值改了。
data:image/s3,"s3://crabby-images/f4cc2/f4cc2ad20dbf20f8446e3f4e5ea2b94c857db78f" alt=""
被迫重新执行 projectionFn:
data:image/s3,"s3://crabby-images/5909e/5909e6b51bce299c290ec21b8029479f3a42739d" alt=""
注意,这个强行改值需要进行两次。
首先获得 feature state:
data:image/s3,"s3://crabby-images/aa842/aa842951682f45724c561067f6ab1fa9bd5b39c9" alt=""
data:image/s3,"s3://crabby-images/23022/23022fc1d8c85d44763194775b4332ff5d94ac46" alt=""
data:image/s3,"s3://crabby-images/feabd/feabd3e0b98c6794d3b2bb83db59fe38ffa4f7e8" alt=""
再从 state 里将 carts 数据提取出来:
data:image/s3,"s3://crabby-images/64eed/64eed753f2b5e1ebdaf40552055a317cd1604fca" alt=""
大功告成:
data:image/s3,"s3://crabby-images/a3fa6/a3fa6e7abf680dc31acd150ff8d2af6ab300cab6" alt=""
更多Jerry的原创文章,尽在:"汪子熙":
data:image/s3,"s3://crabby-images/9d5ff/9d5fffea0e5ec258def5c77c56d04b5c06480366" alt=""
网友评论