- SAP 电商云 Spartacus UI Site Contex
- Angular InjectionToken APP_INITI
- SAP 电商云 Spartacus UI 的 Product C
- SAP 电商云 Spartacus UI 里如何捕捉语言设置的更
- 网站上的 breadcrumb 使用场景浅析
- SAP UI5 sap.ui.vk 命名空间内的控件介绍
- HTML 按钮(button)的 disable 属性和 dis
- SAP 电商云 Spartacus UI 产品搜索结果的设计明细
- SAP 电商云 Spartacus UI Proxy Facad
- Angular @Injectable 注解的工作原理浅析
providers
index.ts 里只有两份 export:
data:image/s3,"s3://crabby-images/86475/86475af8b5811019b2504be9e86ff99ce92d0124" alt=""
context-ids.ts
是一些参数常量。
export const LANGUAGE_CONTEXT_ID = 'language';
export const CURRENCY_CONTEXT_ID = 'currency';
export const BASE_SITE_CONTEXT_ID = 'baseSite';
export const THEME_CONTEXT_ID = 'theme';
context-service-map.ts (ContextServiceMap)
ContextServiceMap 是一个 map 结构,key 是字符串,value 是这种 site context 对应的 SiteContext Facade 类?
data:image/s3,"s3://crabby-images/bf1f0/bf1f09e7ce3aefcbde370bba89540702e0a9e986" alt=""
比如我们之前在 facade
文件夹里讨论过的:
@Injectable()
export class CurrencyService implements SiteContext<Currency> {
constructor(
protected store: Store<StateWithSiteContext>,
protected config: SiteContextConfig
) {}
serviceMapFactory
工厂函数,负责提供 ContextServiceMap 的实现?
data:image/s3,"s3://crabby-images/1ae8f/1ae8fec2017c6e2663d7a961cff1aab00c5fd17d" alt=""
什么时候 ContextServiceMap 的实例会被调用到?
data:image/s3,"s3://crabby-images/08e67/08e672143e59bd74dad4ad47d632e8f8fc05ac04" alt=""
这里只有类的定义,并没有类的实例化过程:
data:image/s3,"s3://crabby-images/3b4c0/3b4c0ee518ed7ff70773db3c1f5830bf29a2942e" alt=""
site-context-params-providers (siteContextParamsProviders)
这个类没有被 index.ts 导出。从注释也能看出,这是有意为之,不将其暴露到 public API 去。
import { Provider } from '@angular/core';
import { UrlSerializer } from '@angular/router';
import { SiteContextParamsService } from '../services/site-context-params.service';
import { SiteContextUrlSerializer } from '../services/site-context-url-serializer';
// functions below should not be exposed in public API:
export const siteContextParamsProviders: Provider[] = [
SiteContextParamsService,
SiteContextUrlSerializer,
{ provide: UrlSerializer, useExisting: SiteContextUrlSerializer },
];
提供了一些 provider 的实现,SiteContextUrlSerializer 提供了 Angular UrlSerializer 的实现。
context-service-providers.ts
initializeContext
这个函数就是一个包裹函数,从 site-context 平级的 config 文件夹里导入 ConfigInitializerService 和 site-context 内部的 service 文件夹内的 SiteContextRoutesHandler,然后调用这两个导入的函数的对应方法。
data:image/s3,"s3://crabby-images/5a962/5a962ca3799a0d78e0cea413e4a1b5bfc296d8be" alt=""
回答两个问题:
(1) initializeContext 函数什么时候被调用?
这个调用又分为两个维度来讨论。
data:image/s3,"s3://crabby-images/d33f1/d33f1b49fdccc5441d61541722668b20a54fb04c" alt=""
第13行的代码,在 Angular 依赖注入框架内执行:
data:image/s3,"s3://crabby-images/64e68/64e68583e168d2e8c116fa9ef541b3a6e0b75a0f" alt=""
这比较合理,因为就在这个文件的尾部,initializeContext
作为 APP_INITIALIZER
被调用。
data:image/s3,"s3://crabby-images/b91e5/b91e5ab759e63423f67f668e03aac67c5ad9829a" alt=""
稍后,Angular APP_INITIALIZER 所有的 provider 也被调用:
data:image/s3,"s3://crabby-images/51044/510446bd56ec52d651a25a94dcc6944cf88b208b" alt=""
(2) 这个函数的 23 行 init 方法执行了什么逻辑?
这个 init 方法,就是 services
问就按家里的实现,即通过 url 里包含的 language 和 currency 参数,设置 site context 的过程。
data:image/s3,"s3://crabby-images/f6f24/f6f24fd29aa9c2a01f3017e17550410a54d710ec" alt=""
总结
本文介绍了 SAP 电商云 Spartacus UI site-context 模块里 providers 文件夹里的实现明细。
网友评论