从调用栈能看出,准备加载 multi cart :
我现在希望通过代码调试,找到具体是哪一行抛出的 action:
从调用栈里没找到也没关系,通过源代码搜索也很好找:
[Cart] Load Cart
从 callstack 真的没有找到:
setDeliveryModeSuccess 之后,立即重新 LoadCart:
cart 数据加载完毕:
checkout detail 又开始加载了:
这个 checkout detail,会影响我们这个 in process$:
48 行的 isLoading 又变为 true了,这会导致 UI option 重新处于 disabled 状态。
等 checkout details 执行成功后,UI 重新处于可编辑状态:
[Checkout] Checkout Details
Checkout 触发代码:
为什么设置 delivery mode,会触发 59行代码?
当 cart 的 stable 状态发生变化时,就会触发59行的回调,可以理解成依赖。
通过这段代码验证:
import './style.css'; import { combineLatest, interval, tap } from 'rxjs'; const number1 = interval(1000); const number2 = interval(5000); const combined = combineLatest([number1, number2]); const tapped = combined.pipe( tap(([number1, number2]) => console.log('number1: ', number1, ' number2', number2) ) ); tapped.subscribe();
输出:
combinedLatest 输入参数有任意一个 Observable 发生了变化,则 tap 都会触发。
现在的问题是,从我点了 input radio 之后,“Premium Delivery”:
sequential: