login.component.html:
<ng-container *ngIf="user$ | async as user; else login">
<div class="cx-login-greet">
{{ 'miniLogin.userGreeting' | cxTranslate: { name: user.name } }}
</div>
<cx-page-slot position="HeaderLinks"></cx-page-slot>
</ng-container>
<ng-template #login>
<a role="link" [routerLink]="{ cxRoute: 'login' } | cxUrl">{{
'miniLogin.signInRegister' | cxTranslate
}}</a>
</ng-template>
如果user$可用,则显示class为cx-login-greet的div标签页:
data:image/s3,"s3://crabby-images/f4a88/f4a88be71b1d26533e57a221016c422337f4bdec" alt=""
data:image/s3,"s3://crabby-images/1c589/1c589da59da24e87e03d646fdb9f2898314e6317" alt=""
同时通过cx-page-slot显示HeaderLinks,否则进入*ngIf的else分支,显示login模板的内容。
为了判断user$是否可用,通过async pipe展开:
data:image/s3,"s3://crabby-images/61133/61133b4473bb87847d4afe644135cf75b4d905bd" alt=""
data:image/s3,"s3://crabby-images/4cc19/4cc192c49740ba848e02d6516f37c99b2c4eed57" alt=""
这个v1就是user$:
data:image/s3,"s3://crabby-images/034d2/034d2b07334644ccf556f8e5b6d2b92bf801fa80" alt=""
data:image/s3,"s3://crabby-images/922cd/922cd8721612ba3ee365edc8a72bfd141f8dc740" alt=""
data:image/s3,"s3://crabby-images/4df43/4df43dfbb25e113cfc26d045b342c97a952357b8" alt=""
async pipe的transform方法里会调用subscribe:
data:image/s3,"s3://crabby-images/0dfde/0dfdedad65841059e6b64fbecc492176fa56cebf" alt=""
data:image/s3,"s3://crabby-images/3d4d1/3d4d1bc37014d0dac03d5e639cdfa179be59c82e" alt=""
上图准备执行这段代码了:
data:image/s3,"s3://crabby-images/8dc18/8dc183540dadae4dca6f5ff116c9219e17d2775f" alt=""
上面的TypeScript运行时被展开成了:
(isUserLoggedIn) => {
if (isUserLoggedIn) {
return this.userService.get();
}
else {
return Object(rxjs__WEBPACK_IMPORTED_MODULE_1__…
执行tap:
data:image/s3,"s3://crabby-images/13310/13310d07ef9136ef77c6fe36d7d401ebb8d7bde3" alt=""
data:image/s3,"s3://crabby-images/a5dc3/a5dc3aab2a92cebdffe4625d6a835ca6a4415981" alt=""
更多Jerry的原创文章,尽在:"汪子熙":
data:image/s3,"s3://crabby-images/5c245/5c2451227ab390a16b5fe9bdbec5d83178d7661c" alt=""
网友评论