SAP 电商云 Spartacus UI 修改 Delivery Mode 触发的三个 HTTP 请求(一)

简介: SAP 电商云 Spartacus UI 修改 Delivery Mode 触发的三个 HTTP 请求

LoaderState:


loading 状态在 true 和 false 之间的切换,通过 loader

.reducer.ts 里的 reducer 函数进行。每次通过 store.dispatch 往 store 里投递新的 action 时,都会触发该 reducer 的执行。

62.png

添加上打印日志:

63.png

设置 delivery mode 的用户点击,触发一个 put 请求,两个 get 请求:

64.png

4秒的 proces 从 loading 到 loaded

2秒的 Multi Cart Data 从 loading 到 loaded

3秒的 Checkout Details 从 loading 到 loaded

65.png

为什么会打印两次?

66.png

从时间轴能看出是串行关系:

67.png

HTTP PUT 先执行完,然后才是 cart 数据的读取。

完整的时间轴:

68.png

69.png

逐一解答。


process

当我点击 radio input 之后,通过了下图 245 行 filter projection 的考验之后,进入 251 行 store.dispatch 操作。因此,如果当前 cart 不 stable,并且 checkout Service 处于 loading 状态时, 不会执行到 251 行:

71.png

当前 isLoading 为 false,只有这样才能通过 245 行的 filter 操作:

1.png

checkout Store 是构造函数依赖注入的 store API.

所以 process 就是 setDeliveryMode 的 entity 类型。

2.png

上图的 dispatch 操作,居然会触发到我应用代码里的 tap hook. 这是期望中的行为,因为 deliveryModeSetInProcess 通过 combineLatest 返回,从语义上说,checkoutService 的 loading 状态,和 Checkout Delivery Service 的 getSetDeliveryModeProcess 方法,只要有任意发生变化,都会触发 deliveryModeSetInProcess$ 的 subscribe 执行。

3.png这个常量好面熟:

4.png

tap 这里为什么是 true?

5.png因为这里是 true:

6.png

7.png会调用两次,打印第二次 tap hook。如果不用 combineLatest,会不会还是有这个行为?

8.png

9.png标志着 delivery mode set 完成:

10.png

tap hook 再次触发:

11.png

这次就看不到明显的是通过 application code 来触发的痕迹:

image.png并不是通过下图这段代码触发的:

13.png

紧接着,开始 load cart 数据了:Multi Cart Data

14.png

15.png


3.png


目录
相关文章
|
运维 Serverless 调度
函数计算产品使用问题之怎么在HTTP触发的函数里添加或读取自定义头部
函数计算产品作为一种事件驱动的全托管计算服务,让用户能够专注于业务逻辑的编写,而无需关心底层服务器的管理与运维。你可以有效地利用函数计算产品来支撑各类应用场景,从简单的数据处理到复杂的业务逻辑,实现快速、高效、低成本的云上部署与运维。以下是一些关于使用函数计算产品的合集和要点,帮助你更好地理解和应用这一服务。
|
存储 运维 监控
函数计算产品使用问题之如何在控制台配置HTTP触发器并使用HTTP请求触发
阿里云Serverless 应用引擎(SAE)提供了完整的微服务应用生命周期管理能力,包括应用部署、服务治理、开发运维、资源管理等功能,并通过扩展功能支持多环境管理、API Gateway、事件驱动等高级应用场景,帮助企业快速构建、部署、运维和扩展微服务架构,实现Serverless化的应用部署与运维模式。以下是对SAE产品使用合集的概述,包括应用管理、服务治理、开发运维、资源管理等方面。
302 6
|
JavaScript 前端开发 API
【Azure 应用服务】Azure Function HTTP 触发后, 230秒就超时。而其他方式触发的Function, 执行5分钟后也超时,如何调整超时时间?
【Azure 应用服务】Azure Function HTTP 触发后, 230秒就超时。而其他方式触发的Function, 执行5分钟后也超时,如何调整超时时间?
337 0
|
Serverless
在函数计算中实现定时触发自定义环境中的 HTTP 函数
在函数计算中实现定时触发自定义环境中的 HTTP 函数
249 0
|
XML JSON 前端开发
Qt+QtWebApp开发笔记(五):http服务器html中使用json触发ajax与后台交互实现数据更新传递
前面完成了页面的跳转、登录,很多时候不刷新页面就想刷新局部数据,此时ajax就是此种技术,且是异步的。   本篇实现网页内部使用js调用ajax实现异步交互数据。   在js中使用 ajax是通过XMLHttpRequest来实现的。
|
存储 JavaScript 前端开发
SAP 电商云的构建过程中涉及到的三种不同环境类型
SAP 电商云的构建过程中涉及到的三种不同环境类型
415 0
SAP 电商云的构建过程中涉及到的三种不同环境类型
SAP Spartacus页面底部的Component请求
SAP Spartacus页面底部的Component请求
217 0
SAP Spartacus页面底部的Component请求
|
消息中间件 API 开发工具
实时获取短信发送状态,这个功能别错过!|阿里云短信服务
短信回执可以让你对每一次短信的审核和送达状态了如指掌,怎么样才能摆脱“状态轮询”,实时获取各种状态呢?
2285 17
28个项目实战典型案例总结收获
28个项目实战典型案例总结收获
485 0
|
分布式计算 Spark Hbase
【降价信息】云HBase X-Pack最高降价31%,再次释放大数据处理红利
阿里云中国站云HBase X-Pack中的Spark服务将于2019年7月16日进行价格下调。
979 0