SAP 电商云 Spartacus UI 根据 CMS Comp
2021-12-18 本文已影响0人
华山令狐冲
uid:LanguageComponent
data:image/s3,"s3://crabby-images/0478f/0478f0b9c0cd79c35370cfff44ad392e0877f4ce" alt=""
data:image/s3,"s3://crabby-images/5ef0c/5ef0c5208b5a1943dfaf474c78a5fc54a4317cf2" alt=""
getComponentData 内部会调用 createComponentData:
data:image/s3,"s3://crabby-images/7c610/7c61039fce45d9d5e57c9c28f1ca9db6ae26c553" alt=""
如果当前不可用,会加载:
data:image/s3,"s3://crabby-images/a399f/a399f0275125656f982ce1131d9543443de1bcb5" alt=""
data:image/s3,"s3://crabby-images/e1135/e1135ba72747e1b313b8e2b6d02eeaa15d00ebf8" alt=""
data:image/s3,"s3://crabby-images/9a149/9a1492c3cd2ae2082f6c26b77141ccc60d67fef2" alt=""
最终从 NgRx store 即内存存储中读取的 Component 数据:
data:image/s3,"s3://crabby-images/329cd/329cd5e9e4e7c89bb4642ff4cac9616e58bfe78e" alt=""
那么从概念上说,这些数据一定是对应的 effect 调用 OCC API 从 Commerce Cloud 后台读取,并且使用 reducer 添加到 Store 里的。
这里就是 Effect 读取成功的代码位置:
data:image/s3,"s3://crabby-images/8dd35/8dd3526800ac9de2aca30195f4b032bd06cec815" alt=""
运行时调试发现:
data:image/s3,"s3://crabby-images/74497/74497e91cccb0d55e4f939b9fc775a36f24cf1e0" alt=""
Home page 下所有的 CMS Component,一次性被读取回来了:
data:image/s3,"s3://crabby-images/22dae/22daed3579d4b13b31e2fe46118a9981f1a9cb80" alt=""
data:image/s3,"s3://crabby-images/ad5b9/ad5b95437d9e8533173f83b030f4836a2d06b09a" alt=""
data:image/s3,"s3://crabby-images/6dc07/6dc07f874d0feacd83568c21621e6c664aa57400" alt=""
更多Jerry的原创文章,尽在:"汪子熙":
data:image/s3,"s3://crabby-images/9d5ff/9d5fffea0e5ec258def5c77c56d04b5c06480366" alt=""