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


目录
相关文章
|
2月前
|
应用服务中间件 nginx
百度搜索:蓝易云【HTTP请求是如何关联Nginx server{}块的?】
总结来说,Nginx中的 `server{}`块用于关联HTTP请求和虚拟主机,通过配置不同的 `server{}`块,可以实现多个域名或IP地址的请求分发和处理。这样,Nginx可以根据不同的请求来提供不同的服务和内容。
26 0
|
2月前
|
JavaScript
Node.js【GET/POST请求、http模块、路由、创建客户端、作为中间层、文件系统模块】(二)-全面详解(学习总结---从入门到深化)(上)
Node.js【GET/POST请求、http模块、路由、创建客户端、作为中间层、文件系统模块】(二)-全面详解(学习总结---从入门到深化)
24 0
|
2月前
|
JavaScript
Node.js【GET/POST请求、http模块、路由、创建客户端、作为中间层、文件系统模块】(二)-全面详解(学习总结---从入门到深化)(下)
Node.js【GET/POST请求、http模块、路由、创建客户端、作为中间层、文件系统模块】(二)-全面详解(学习总结---从入门到深化)
22 0
|
2月前
|
Java API Spring
使用OkHttp在Spring Boot应用中发送HTTP请求
使用OkHttp在Spring Boot应用中发送HTTP请求
27 0
|
2月前
|
存储 缓存 安全
面试题:HTTP 协议包括哪些请求?
面试题:HTTP 协议包括哪些请求?
19 0
|
2月前
|
移动开发 自然语言处理 网络协议
Http解析实现/服务器Get请求的实现
Http解析实现/服务器Get请求的实现
31 0
|
2月前
|
Web App开发 网络协议 Linux
Linux C/C++ 开发(学习笔记十 ):实现http请求器(TCP客户端)
Linux C/C++ 开发(学习笔记十 ):实现http请求器(TCP客户端)
25 0
|
28天前
cas5.3 使用http方式请求
cas5.3 使用http方式请求
【计算机网络】如何让客户端构造一个HTTP请求-2
【计算机网络】如何让客户端构造一个HTTP请求-2
【计算机网络】如何让客户端构造一个HTTP请求-2
|
2月前
|
存储 前端开发 JavaScript
【计算机网络】如何让客户端构造一个HTTP请求-1
【计算机网络】如何让客户端构造一个HTTP请求-1
【计算机网络】如何让客户端构造一个HTTP请求-1