- HTML 按钮(button)的 disable 属性和 dis
- SAP 电商云 Spartacus UI 的 Product C
- SAP 电商云 Spartacus UI Store 相关的设计
- SAP 电商云 Spartacus UI 从 CMS 取回 sl
- 网站上的 breadcrumb 使用场景浅析
- Angular InjectionToken APP_INITI
- SAP UI5 sap.ui.vk 命名空间内的控件介绍
- SAP 电商云 Spartacus UI 产品搜索结果的设计明细
- SAP 电商云 Spartacus UI Proxy Facad
- Angular @Injectable 注解的工作原理浅析
Store
state.ts
定义了和 Site Context 业务相关的 State 数据模型。
定义数据模型的套路是:
export const SITE_CONTEXT_FEATURE = 'siteContext';
export interface StateWithSiteContext {
[SITE_CONTEXT_FEATURE]: SiteContextState;
}
这是最顶层的 State 模型了。
SiteContextState 包含了三个子 State:
export interface SiteContextState {
languages: LanguagesState;
currencies: CurrenciesState;
baseSite: BaseSiteState;
}
以 CurrenciesState 为例,不仅包含了 Entities 列表,还包含了当前 Active 状态的 Currency:
export interface CurrenciesState {
entities: CurrencyEntities;
activeCurrency: string;
}
再定义 Entities 列表:
export interface CurrencyEntities {
[isocode: string]: Currency;
}
以上就是 Site Context 领域所需的 State 数据结构。
注意 SITE_CONTEXT_FEATURE 的使用场合,除了本文件定义 feature state 之外,还用在下列两个文件内:
data:image/s3,"s3://crabby-images/8fa5e/8fa5e1f6bbd72bedb7908d7d2d25b563a289867c" alt=""
场景1:用来创建 feature selector:
data:image/s3,"s3://crabby-images/05634/05634a5b394d771dd78195535f9a5db9b497297d" alt=""
场景2:使用 StoreModule.forFeature 注册 store:
data:image/s3,"s3://crabby-images/6b6fa/6b6fa994cd83ada3c0c14cf2b8c8b3503bf5d557" alt=""
当使用 createSelector 和 createFeatureSelector 函数时,@ngrx/store 会跟踪调用选择器函数的最新参数。 因为选择器是纯函数,所以当参数匹配时可以返回最后一个结果,而无需重新调用选择器函数。 这可以提供性能优势,特别是对于执行昂贵计算的选择器。这种做法称为 memoization
.
createFeatureSelector 是返回顶级(Top Level
)的 Feature State
的便捷方法。 它为状态的特征切片(Feature Slice
)返回一个类型化(typed
)的选择器函数。
注意 createFeatureSelector 的调用有两种写法。
写法1
下图 2 必须是 1 的一个切片,并且 3 的类型必须和 2 的类型一致:
data:image/s3,"s3://crabby-images/d22b4/d22b4e2bfc60fc55718f3d2c04a1219b9e3d1d29" alt=""
2 的位置其实就是 result 的位置:
data:image/s3,"s3://crabby-images/79d32/79d32db411ca58c81814904ba50f6dffa7140794" alt=""
写法2
import { createSelector, createFeatureSelector } from '@ngrx/store';
export const featureKey = 'feature';
export interface FeatureState {
counter: number;
}
export interface AppState {
feature: FeatureState;
}
export const selectFeature = createFeatureSelector<AppState, FeatureState>(featureKey);
export const selectFeatureCount = createSelector(
selectFeature,
(state: FeatureState) => state.counter
);
data:image/s3,"s3://crabby-images/ff348/ff348d6d0cbdae0210d2cf15c2a0844c6a35e974" alt=""
我做过测试,在 SAP 电商云 Spartacus UI 项目里,两种写法完全等价:
data:image/s3,"s3://crabby-images/5a2b9/5a2b9860467c5d7d3664742419338010e0ea2f2e" alt=""
可以顺利通过编译:
data:image/s3,"s3://crabby-images/397f4/397f4b36cb03203d764ea81bb12a6388cd1ea7e7" alt=""
网友评论