- SAP 电商云 Spartacus UI 的 Product C
- 关于 SAP 电商云 Spartacus UI Navigati
- 网站上的 breadcrumb 使用场景浅析
- SAP UI5 sap.ui.vk 命名空间内的控件介绍
- HTML 按钮(button)的 disable 属性和 dis
- SAP 电商云 Spartacus UI 产品搜索结果的设计明细
- SAP 电商云 Spartacus UI Proxy Facad
- Angular @Injectable 注解的工作原理浅析
- 关于 Angular 部署以及 index.html 里 bas
- SAP 电商云 Spartacus UI 从 CMS 取回 sl
第一次触发的时候,navigation.uid 并没有值:
下图:navigation.service 的 getNavigationNode 方法。
data:image/s3,"s3://crabby-images/ecfdf/ecfdf349173a3cda9a508722e36fa4b4fe5e0537" alt=""
触发这个订阅的入口:
data:image/s3,"s3://crabby-images/54650/54650ae433f828f39db547f0c4f7c39255c2d50b" alt=""
<cx-navigation-ui
*ngIf="data$ | async as data"
[node]="node$ | async"
[ngClass]="data.styleClass"
[wrapAfter]="data.wrapAfter"
[resetMenuOnClose]="data.resetMenuOnClose"
></cx-navigation-ui>
查看 data$ 的数据源。
来自 navigation service 的 createNavigation
方法。
data:image/s3,"s3://crabby-images/0e890/0e8908d8596f21e2b60762bd6662d34fe28b7009" alt=""
createNavigation 内部,会将 cmsComponentdata 和 getNavigationNode 的结果,做一个 combination.
data:image/s3,"s3://crabby-images/5cc53/5cc53245465cf5779249e47addd01d0979e1494c" alt=""
上图第 23 行代码我们使用了 combineLatest
操作符。
当 Angular 应用里存在多个长期存在的(Long-lived) observables 相互依赖以进行某些计算或执行 determination 逻辑时,推荐使用此运算符。
请注意,在每个可观察对象至少发出一个值之前,combineLatest 不会发出初始值。 这与 withLatestFrom 的行为相同,并且可能是一个潜在的问题(gotcha),因为既没有输出也没有错误,此时我们的一个(或多个)内部可观察对象可能没有按预期运行,或者发生了订阅延迟现象(subscription is late)。
最后,如果我们正在使用仅发出一个值的可观察对象,或者只需要每个对象在完成前的最后一个值,则 forkJoin 可能是更好的选择。
看个具体的例子:
import { timer, combineLatest } from 'rxjs';
// timerOne emits first value at 1s, then once every 4s
const timerOne$ = timer(1000, 4000);
// timerTwo emits first value at 2s, then once every 4s
const timerTwo$ = timer(2000, 4000);
// timerThree emits first value at 3s, then once every 4s
const timerThree$ = timer(3000, 4000);
// when one timer emits, emit the latest values from each timer as an array
combineLatest(timerOne$, timerTwo$, timerThree$).subscribe(
([timerValOne, timerValTwo, timerValThree]) => {
/*
Example:
timerThree first tick: 'Timer One Latest: 0, Timer Two Latest: 0, Timer Three Latest: 0
timerOne second tick: 'Timer One Latest: 1, Timer Two Latest: 0, Timer Three Latest: 0
timerTwo second tick: 'Timer One Latest: 1, Timer Two Latest: 1, Timer Three Latest: 0
*/
console.log(
`Timer One Latest: ${timerValOne},
Timer Two Latest: ${timerValTwo},
Timer Three Latest: ${timerValThree}`
);
}
);
执行结果:
data:image/s3,"s3://crabby-images/3d4f9/3d4f9b857feddb580ac9187573c14e7b5f81386b" alt=""
getNavigationEntryItems 第一次总是会 undefined,这是为什么呢?
data:image/s3,"s3://crabby-images/d2c50/d2c502f1aa3384a258db75716555f89de12dee22" alt=""
从 store 里读取,第一次 store 肯定是空的,正常现象:
data:image/s3,"s3://crabby-images/35ee5/35ee5ffd4386f58585c49c8125ec267fb283ac59" alt=""
按需加载:
data:image/s3,"s3://crabby-images/77a13/77a13a5c8dbb7f9209f1a6bb6531707e49a3a808" alt=""
发一个 load action:
data:image/s3,"s3://crabby-images/1fd34/1fd34a20d52107716d4766ab972301b0561ebc3e" alt=""
在 success 里设置一个断点:
data:image/s3,"s3://crabby-images/7644c/7644c0f3d0f7efd511792b2458ba3090717147a1" alt=""
NavigationEntryItemEffects 负责加载:
data:image/s3,"s3://crabby-images/d0002/d00027d1dc933a47c4aff3bf455e1aa840d0e504" alt=""
加载成功:
data:image/s3,"s3://crabby-images/8bfaa/8bfaa88a18eb26062ced0c552960ec70275af236" alt=""
此时 items 就有值了:
data:image/s3,"s3://crabby-images/93c17/93c1747ff8be98fed4e55f0eaf86619a12724e51" alt=""
网友评论