- SAP 电商云 Spartacus UI Cart ID 的 l
- SAP 电商云 Spartacus UI 的 Product C
- 网站上的 breadcrumb 使用场景浅析
- SAP 电商云 Spartacus UI Cart ID 的数据
- SAP UI5 sap.ui.vk 命名空间内的控件介绍
- HTML 按钮(button)的 disable 属性和 dis
- SAP 电商云 Spartacus UI 产品搜索结果的设计明细
- SAP 电商云 Spartacus UI Proxy Facad
- Angular @Injectable 注解的工作原理浅析
- 关于 Angular 部署以及 index.html 里 bas
IsStable:首先 false,然后 true
data:image/s3,"s3://crabby-images/733d7/733d72afcf271de6da68fd716b76c75c78313a1a" alt=""
@NgModule()
export class CartPersistenceModule {
static forRoot(): ModuleWithProviders<CartPersistenceModule> {
return {
ngModule: CartPersistenceModule,
providers: [
{
provide: APP_INITIALIZER,
useFactory: cartStatePersistenceFactory,
deps: [MultiCartStatePersistenceService, ConfigInitializerService],
multi: true,
},
提供的函数在应用程序启动时注入并在应用程序初始化期间执行。 如果这些函数中的任何一个返回 Promise 或 Observable,则在 Promise 解决或 Observable 完成之前,初始化不会完成。
例如,我们可以创建一个加载语言数据或外部配置的工厂函数,并将该函数提供给 APP_INITIALIZER 令牌。 该函数在应用程序引导过程中执行,所需数据在启动时可用。
应用程序初始化时,调用 cartStatePersistenceFactory
:
Angular 框架调用所有的 app initializer:
data:image/s3,"s3://crabby-images/140ed/140ed4d2706f04ff5bf648018d83db0ba9fab7a7" alt=""
这个 init 需要返回一个 promise 对象:
data:image/s3,"s3://crabby-images/a22a1/a22a1be69286ba25c08cf7bcb23cc34732fc7b20" alt=""
toPromise 对象内会调用 subscriber 的 next 方法:
data:image/s3,"s3://crabby-images/b069f/b069f1f40a83f8a094533ead29f98cc5234250f1" alt=""
调用 cartStatePersistenceService.initSync()
:
data:image/s3,"s3://crabby-images/7ee01/7ee010fbc94ab790652f1a245c6b8b5822c96eaa" alt=""
cart 信息存储在 local storage 里:
data:image/s3,"s3://crabby-images/3a822/3a822f9dcb2d0666c290897975989e9044f12929" alt=""
从 local storage 里取出的数据:
data:image/s3,"s3://crabby-images/71916/7191691e3f430f802cdaaf58ffb382c86b90fb99" alt=""
生成 key:
data:image/s3,"s3://crabby-images/11ff8/11ff8c4e9bfd6a0b22c6416d4df03fb901333542" alt=""
SSR 模式下没有浏览器 storage:
data:image/s3,"s3://crabby-images/6a9ca/6a9caca94da376ac54ec4aa2c64339752d522157" alt=""
取出浏览器 local storage 里存储的当前 active cart id:2007
data:image/s3,"s3://crabby-images/366f2/366f25835b1aac8bfcffd0bfb12e0d7db233d84c" alt=""
也就是下图高亮的 cart id:
data:image/s3,"s3://crabby-images/f4d37/f4d37fe8789169d6741c6ac8bc41b1c7d9e5000d" alt=""
不同的 base site,其对应的 cart id 不一致。
得到 cart id 后,调用 onRead
方法:
data:image/s3,"s3://crabby-images/fc761/fc761fb0870eb8654942eb686a084e1645622ec6" alt=""
首先 clear Cart 状态:
data:image/s3,"s3://crabby-images/e59ae/e59aee964b4dfabd4ed42f234d96a22a22428587" alt=""
data:image/s3,"s3://crabby-images/e2a83/e2a8322a032ada0cb8b9b146f8ddc2e9f88fa26a" alt=""
data:image/s3,"s3://crabby-images/62a0f/62a0fcbb286964d0eb37cf43ee54c4420a4183d3" alt=""
进入 scheduleMessage,即利用 store 进行 Action dispatch,很有可能是一个异步过程。
data:image/s3,"s3://crabby-images/9d781/9d7811a1d46f60162e6da32c4399623e3c724bf7" alt=""
然而没有进入异步 schedule 的分支:
data:image/s3,"s3://crabby-images/d7ee0/d7ee02c034164165b694581956de2ca78bef882a" alt=""
直接调用 scheduler 的 flush 方法:
data:image/s3,"s3://crabby-images/358b4/358b48ce92460a8265a41d11a5f12500b75fd8d6" alt=""
调用 Observer 的 next 方法:
data:image/s3,"s3://crabby-images/e33f0/e33f0cb17baacd6173356d755baeb7df1bcb9417" alt=""
重新计算 state,并且把结果保存:
data:image/s3,"s3://crabby-images/87176/871765158faac0d213c45adad61455e9d1b64a13" alt=""
computedStates = recomputeStates(computedStates, minInvalidatedStateIndex, reducer, committedState, actionsById, stagedActionIds, skippedActionIds, errorHandler, isPaused);
monitorState = monitorReducer(monitorState, liftedAction);
前一个状态:
data:image/s3,"s3://crabby-images/23091/230911124b10862ab0c60a0cfe0743c630bd7040" alt=""
调用 reducer 计算下一个状态:
data:image/s3,"s3://crabby-images/f347a/f347a2c3fc7c3c35599d097794fea055c2a12618" alt=""
这就是 Spartacus 自己实现的 reducer 了:
data:image/s3,"s3://crabby-images/27cf6/27cf6ce73ff06a6f718963cab6b15b906955de76" alt=""
data:image/s3,"s3://crabby-images/39fcb/39fcbf9d809f5b9ca1a44db2f4ea48271ac5645e" alt=""
data:image/s3,"s3://crabby-images/fc943/fc943f85601c0988bfebe2573c14256c1f0d97b4" alt=""
data:image/s3,"s3://crabby-images/ab127/ab1278f621d34e5bb340fff2557837868193641f" alt=""
export function reducer(
state = initialState,
action: CmsActions.LoadCmsPageDataSuccess
): EntityState<Page> {
switch (action.type) {
case CmsActions.LOAD_CMS_PAGE_DATA_SUCCESS: {
const page: Page = action.payload;
return { ...state, entities: { ...state.entities, [page.pageId]: page } };
}
}
return state;
}
data:image/s3,"s3://crabby-images/d19f5/d19f59eff41a3d2c165346881ddd839421237862" alt=""
会依次执行很多对应的 reducer:
data:image/s3,"s3://crabby-images/c57f4/c57f47275e6ee8ce1f485fe8e1118ec73bba1f41" alt=""
网友评论