- SAP Commerce Accelerator和SAP Spa
- SAP Commerce Cloud Spartacus UI
- SAP Commerce Cloud Spartacus UI
- SAP Commerce Cloud Spartacus UI
- SAP Commerce Cloud Spartacus UI
- SAP Commerce Cloud Spartacus UI
- SAP Commerce Cloud Spartacus UI
- SAP Commerce Cloud Spartacus UI
- 如何在 SAP 电商云 Spartacus UI 里新建一个页面
- 网站上的 breadcrumb 使用场景浅析
在 components.reducer.ts 里,loaderReducer 函数,会根据输入的 entityType,返回一阶 reducer.
data:image/s3,"s3://crabby-images/692f8/692f804fd32bf3a2bbe7c4bf1027a6345db282e2" alt=""
然后在代码第86行,调用该一阶 reducer 进行状态转换,返回新的状态。
在 cms store reducers index.ts 里,该 reducer 被导入,见代码第21行:
data:image/s3,"s3://crabby-images/eb97b/eb97b04634b8b8f764cdcac5dea2ed4f09f37982" alt=""
然后,在第49行,调用 entityReducer,给 COMPONENT_ENTITY 类型生产一个新的 reducer 函数。
data:image/s3,"s3://crabby-images/2bfe6/2bfe66c074d5cf13531ba0176f503f64bb755aef" alt=""
这个新的 reducer 的函数体:
data:image/s3,"s3://crabby-images/e87d4/e87d4acdc88a0ec15557f36ddea6803bb04104fb" alt=""
getReducer 在何时会被调用?
data:image/s3,"s3://crabby-images/bab54/bab542d581895fad621886f7776b9d79ce35b2ec" alt=""
除了 index.ts 之外,其他都是单元测试代码:
data:image/s3,"s3://crabby-images/34eb5/34eb59508f6524cd4742ecf676ea6e1a7f91cf30" alt=""
通过工厂方法 + injection token 的方式暴露给外部:
data:image/s3,"s3://crabby-images/537e1/537e1570579ed077d04ec610e0a6354bc7538454" alt=""
最后被导入到 CmsStore module 的 providers 区域里即可:
data:image/s3,"s3://crabby-images/fd43b/fd43baadf7904a684cfbdbc4e98b5fdbebac428a" alt=""
更多Jerry的原创文章,尽在:"汪子熙":
data:image/s3,"s3://crabby-images/9d5ff/9d5fffea0e5ec258def5c77c56d04b5c06480366" alt=""
网友评论