- Spartacus Storefront 产品明细页面里的 Ad
- SAP Spartacus的基于outlet的页面扩展
- Spartacus Storefront 里的 currency
- SAP Commerce Accelerator和SAP Spa
- 关于 SAP Spartacus 的 Theme 颜色主题
- SAP Spartacus Storefront页面的page
- 关于 SAP 电商云首页加载时触发的 OCC API 请求
- StorefrontModule和B2CStorefrontMo
- 自定义SAP Spartacus Cart界面
- SAP Spartacus产品明细页面用Observable显示
这个 configurable 产品(搜索 home theater)明细页面里,没有看到 add to wish list 的超链接:
data:image/s3,"s3://crabby-images/38266/38266fe4cc8eef094472b8bfb3f57c40ae7325d0" alt=""
有时我们会发现 Add to wish list 按钮为空的情况:
data:image/s3,"s3://crabby-images/1fa0b/1fa0b33557eb93c7f234f9591434708c90319c92" alt=""
选择器 cx-add-to-wishlist
下是空的,没有任何元素,如上图所示。
从 ng-container
里的 ngIf
指令不难发现,add to wish list 的工作前提,是当前产品已经成功被获取,并且用户处于登录状态。
data:image/s3,"s3://crabby-images/dc86b/dc86b9c4e4fe5bed5969a651e11586b552ae5cd0" alt=""
在 Component AddToWishListComponent
里打印出当前 product 的详细信息:
data:image/s3,"s3://crabby-images/a359a/a359a9eefeef497cab88b72eb6cd427fa480aae6" alt=""
data:image/s3,"s3://crabby-images/f3dc3/f3dc3d54f8b9c73b1185652970e890b5ee64d8ff" alt=""
在函数 isUserLoggedIn
里添加 console.log:
data:image/s3,"s3://crabby-images/c738a/c738a04ca004673b84c6b0c6a9879fb31064b4dc" 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/63a68/63a68085517e8947e365f75b8df8079dab37eddb" alt=""
为什么运行时调用的是 asm service:
data:image/s3,"s3://crabby-images/0b6c8/0b6c801abef8da15b6c4c654a6d43b364ca1904a" alt=""
data:image/s3,"s3://crabby-images/b6b50/b6b5093a40767a7f95aa2b9c60be404e7b8d8b8b" alt=""
从代码层面看,应该注入这个 AuthService 才对:
data:image/s3,"s3://crabby-images/1d475/1d4750bcacfa5a9a36a9cb78ac4c7a99ba6dcaf6" alt=""
在 ASM auth service 的构造函数里打印 log:
data:image/s3,"s3://crabby-images/ba14c/ba14c186bee5af058f7cfb0ac36f97f0b248358e" alt=""
加上打印语句:
data:image/s3,"s3://crabby-images/e16fd/e16fdd24ad9ca4e059095a960d8a41061506a16a" alt=""
data:image/s3,"s3://crabby-images/2a5a0/2a5a0ba79f0b7049d095418582bee4c08321a8dd" alt=""
在 add to wish list Component 页面添加调试信息:
<div> {{ product$ | async | json }}</div>
data:image/s3,"s3://crabby-images/07341/07341dc838d76525cb11847891d1cad4276cf256" alt=""
最后的效果:
data:image/s3,"s3://crabby-images/097a0/097a096397d17e42b327b75ea26f610e0f4456db" alt=""
同理:
data:image/s3,"s3://crabby-images/c9287/c928713f1c130c5de9b793bb0aa39b0797e4a2a2" alt=""
data:image/s3,"s3://crabby-images/796e6/796e6a940f1eb39d1428c0dac2d7f184aae06a9d" alt=""
难道是这个 wishlist entries 为空吗?
data:image/s3,"s3://crabby-images/c25ce/c25cef5532b4339948c1f3680fd7b600b09e3301" alt=""
果然:
data:image/s3,"s3://crabby-images/cba63/cba6342d5e46fe676f954ef332451026ba3af10c" alt=""
变量 wishListEntries$
为空,导致 add to wish list 的超链接出不来。
wish list 是通过 cart 来实现的:
data:image/s3,"s3://crabby-images/08d58/08d58d3763b4e26445346282fb531b46d2e4e590" 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,登录后使用购物车代码。
网友评论