Spartacus Storefront 产品明细页面里的 Ad
这个 configurable 产品(搜索 home theater)明细页面里,没有看到 add to wish list 的超链接:
data:image/s3,"s3://crabby-images/c510b/c510b348f8e88fba9a08794e595ccd227612002a" alt=""
有时我们会发现 Add to wish list 按钮为空的情况:
data:image/s3,"s3://crabby-images/bd27a/bd27af90c167ee39f50be75fc765ebb8b82bfb9c" alt=""
选择器 cx-add-to-wishlist
下是空的,没有任何元素,如上图所示。
从 ng-container
里的 ngIf
指令不难发现,add to wish list 的工作前提,是当前产品已经成功被获取,并且用户处于登录状态。
data:image/s3,"s3://crabby-images/a4fb7/a4fb75758b606b564c7d0948d62e31ba2ff88631" alt=""
在 Component AddToWishListComponent
里打印出当前 product 的详细信息:
data:image/s3,"s3://crabby-images/a1c12/a1c12c4b91cfc38524a0eee7483048bec6c06c4a" alt=""
data:image/s3,"s3://crabby-images/7981e/7981ec6c3e717f6213f5ed13cf441c61e2da40cf" alt=""
在函数 isUserLoggedIn
里添加 console.log:
data:image/s3,"s3://crabby-images/e7d7e/e7d7e0f9fb50c08bd752599485aaa03bff1a04fa" alt=""
isUserLoggedIn(): Observable<boolean> {
return this.authStorageService.getToken().pipe(
tap((token) => { console.log('Jerry token: ', token)}),
map((userToken) => Boolean(userToken?.access_token)),
distinctUntilChanged()
);
}
运行时根本没有执行到 console.log 里来:
data:image/s3,"s3://crabby-images/e0743/e0743f92b7f33562b771083051d6a39509dd4282" alt=""
为什么运行时调用的是 asm service:
data:image/s3,"s3://crabby-images/784a8/784a8db429bb96b75fa03a166559f07525d98b30" alt=""
data:image/s3,"s3://crabby-images/9b513/9b513d230c8b2b6d2e7ee72670d987bb95da69ca" alt=""
从代码层面看,应该注入这个 AuthService 才对:
data:image/s3,"s3://crabby-images/7aba0/7aba0395e5ab0dfea28544726e8685a5b00a8885" alt=""
在 ASM auth service 的构造函数里打印 log:
data:image/s3,"s3://crabby-images/b9d2d/b9d2d0e21b98ce607c45724479befc704e78f3fb" alt=""
加上打印语句:
data:image/s3,"s3://crabby-images/6beb5/6beb5ba492209e2cc9c80f037d2fca3b470edd44" alt=""
data:image/s3,"s3://crabby-images/1a739/1a739ab2f35010bd3665c78e0ae6e8a341024649" alt=""
在 add to wish list Component 页面添加调试信息:
<div> {{ product$ | async | json }}</div>
data:image/s3,"s3://crabby-images/92230/922308a723dc3dd9f02d46fabe17729065778ac2" alt=""
最后的效果:
data:image/s3,"s3://crabby-images/ce6bc/ce6bc1cf537d9df69f2398eccba6719aa8815dde" alt=""
同理:
data:image/s3,"s3://crabby-images/7c98c/7c98c21a7197d68da14da80ba51a6693290696a6" alt=""
data:image/s3,"s3://crabby-images/2998c/2998c5a5abb0788e9e55efc1d8f758e4f70f5358" alt=""
难道是这个 wishlist entries 为空吗?
data:image/s3,"s3://crabby-images/b8b98/b8b98268e85d02cb6a14675f3b3c8f4ab9ea599b" alt=""
果然:
data:image/s3,"s3://crabby-images/ba6fe/ba6febb4359e850bdec2d0f2f89375d280877218" alt=""
变量 wishListEntries$
为空,导致 add to wish list 的超链接出不来。
wish list 是通过 cart 来实现的:
data:image/s3,"s3://crabby-images/bf251/bf25143e1fc3a42c1b2e68454acaaa2f1c51a479" alt=""
getWishList(): Observable<Cart> {
return combineLatest([
this.getWishListId(),
this.userService.get(),
this.userIdService.getUserId(),
]).pipe(
distinctUntilChanged(),
tap(([wishListId, user, userId]) => {
if (
!Boolean(wishListId) &&
userId !== OCC_USER_ID_ANONYMOUS &&
Boolean(user) &&
Boolean(user.customerId)
) {
this.loadWishList(userId, user.customerId);
}
}),
filter(([wishListId]) => Boolean(wishListId)),
switchMap(([wishListId]) => this.multiCartService.getCart(wishListId))
);
}
Spartacus 登录后,用户直接回到店面,第一次调用是这样的:
https://localhost:9002/occ/v2/jerry/users/current/carts/0-1bff26781e2c?fields=DEFAULT,potent....
因此,登录后,Spartacus 仍在尝试从 guid 而不是代码加载购物车。
因此,我们会收到 未找到购物车
错误
默认情况下,在 DEMO Spartacus 网站上,登录是直接在同一网站上完成的,
购物车行为是:
- 登录前使用购物车 guid,登录后使用购物车代码。