Raj*_*Raj 0 angular ngrx-router-store angular7
我在组件中有 api 调用,这很耗时,所以我实现了解析器。我希望解析器数据存在于商店中,以供以后使用。我已经实现了 ngrx/store、ngrx/effects 和 ngrx/router-store。
组件中的当前状态
期望状态
为了保存解析器数据,我需要访问有效的解析器数据。所以我可以简单地在组件中调度操作并订阅状态。
{}我总是在 CustomSerializer 中的“数据”中变空。
减速器/index.ts(CustomSerializer)
export interface RouterStateUrl {
url: string;
queryParams: Params;
params: Params;
data: any;
}
export const reducers: ActionReducerMap<State> = {
routerReducer: fromRouter.routerReducer
};
@Injectable()
export class CustomSerializer implements fromRouter.RouterStateSerializer<RouterStateUrl> {
serialize(routerState: RouterStateSnapshot): RouterStateUrl {
let route = routerState.root;
while (route.firstChild) {
route = route.firstChild;
}
const { url, root: { queryParams } } = routerState;
const { params, data } = route;
console.log('routerData in CustomSerializer', { url, queryParams, params, data });
return { url, queryParams, params, data };
}
}Run Code Online (Sandbox Code Playgroud)
减速器 / router.selector.ts
export const getRouterState = createFeatureSelector< RouterReducerState<RouterStateUrl> >('routerReducer');Run Code Online (Sandbox Code Playgroud)
组件.ts
// current state of component
this.subTopicDetails = this.route.snapshot.data['content'];
// new way (desired state), getting "resolver data" from store
this.store.dispatch(new fromCourse.LoadSubTopicDetails);
this.store.select(getSubTopicDetails)
.subscribe(data => this.subTopicDetails = data);Run Code Online (Sandbox Code Playgroud)
您的效果无法(也不应该)访问解析器。
解析器应该检查存储中是否有东西,如果没有,则应该调度一个操作来检索数据。
Todd Motto 通过https://toddmotto.com/preloading-ngrx-store-route-guards上的一些很好的示例很好地解释了这一点。
| 归档时间: |
|
| 查看次数: |
2457 次 |
| 最近记录: |