SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state

简而言之:通过 cart reducer 配合 ngrx-store.js 框架代码。
搜索关键字 LoadCartSuccess:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

运行时断点触发:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

上下文:cartConnector 的回调里。
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

根据关键字 LOAD_CART_SUCCESS 继续搜索:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

我们明确一点:action 在 reducer 里进行状态迁移。
【SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state】根据这个关键字,很快就搜索到了 LOAD_CART_SUCCESS 所在的状态迁移:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

可以看到,http.js 上下文里,调用 observer 的 next 方法,将从 Commerce Cloud 后台返回的 API response,通知其他观察者。
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

body 字段里才是真正的 payload:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

这里使用 .body, 将 payload 解析出来:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

在这段代码里,进行 conversion:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

此处触发 Spartacus team 开发的 mergeMap callback:把 HTTP.js 返回的 response,包装成 LoadCartSuccess 的强类型 payload:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

包装完之后的强类型 response:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

最后 Spartacus cart reducer 被调用:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

reducer 执行完毕后,我们就能在 ngrx-store.js 的 combination 函数里的变量 nextState, 看到最新的 cart memory value:
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

更多Jerry的原创文章,尽在:"汪子熙":
SAP|SAP Spartacus 成功读取 Cart 之后,如何将 payload 插入全局 state
文章图片

    推荐阅读