Angular ovides选择器OOTB?AFAIK ngrx/entity提供了这一点。它没有被记录,当您导入扩展EntityCollectionServiceBase的服务时,您可以访问组件中定义的选择器,但不能访问reducer中的选择器。当您尝试导入扩展类时,您
Angular ovides选择器OOTB?AFAIK ngrx/entity提供了这一点。它没有被记录,当您导入扩展EntityCollectionServiceBase的服务时,您可以访问组件中定义的选择器,但不能访问reducer中的选择器。当您尝试导入扩展类时,您,angular,ngrx,angular-ngrx-data,Angular,Ngrx,Angular Ngrx Data,ovides选择器OOTB?AFAIK ngrx/entity提供了这一点。它没有被记录,当您导入扩展EntityCollectionServiceBase的服务时,您可以访问组件中定义的选择器,但不能访问reducer中的选择器。当您尝试导入扩展类时,您只能访问.prototype。您可以导入EntityCollectionServiceFactory,文档说有一个.create方法,是的,但是当我尝试调用它时,出现了一些错误,因为它不是静态的,但是如果不在构造函数中传递另一个veryLong
ovides选择器OOTB?AFAIK ngrx/entity提供了这一点。它没有被记录,当您导入扩展
EntityCollectionServiceBase
的服务时,您可以访问组件中定义的选择器,但不能访问reducer中的选择器。当您尝试导入扩展类时,您只能访问.prototype。您可以导入EntityCollectionServiceFactory
,文档说有一个.create
方法,是的,但是当我尝试调用它时,出现了一些错误,因为它不是静态的,但是如果不在构造函数中传递另一个veryLongNamedClass,您就无法创建实例。是我在文档中能找到的最接近的东西。在使用ngrx/数据时,您导入了什么来访问已经存在的选择器?嗯,我在文档中没有看到任何地方说ngrx/数据已经创建了选择器。您能给我指一下ngrx/data提供选择器OOTB的文档吗?AFAIK ngrx/entity提供了这一点。它没有被记录,当您导入扩展EntityCollectionServiceBase
的服务时,您可以访问组件中定义的选择器,但不能访问reducer中的选择器。当您尝试导入扩展类时,您只能访问.prototype。您可以导入EntityCollectionServiceFactory
,文档说有一个.create
方法,是的,但是当我尝试调用它时,出现了一些错误,因为它不是静态的,但是如果不在构造函数中传递另一个veryLongNamedClass,您就无法创建实例。是我在文档中能找到的最接近的东西。
import {
Action,
ActionReducer,
ActionReducerMap,
createFeatureSelector,
createSelector,
MetaReducer
} from '@ngrx/store';
import {environment} from '../../environments/environment';
import * as fromRouter from '@ngrx/router-store';
import * as fromDrawer from './drawer';
import {InjectionToken} from '@angular/core';
import {NavigationItem} from '../models/navigation-item';
export interface State {
router: fromRouter.RouterReducerState<any>;
drawerNavigationItems: fromDrawer.State;
}
export const ROOT_REDUCERS = new InjectionToken<ActionReducerMap<State, Action>>('Root reducers token', {factory: () => ({
router: fromRouter.routerReducer,
drawerNavigationItems: fromDrawer.reducer,
}),
});
export const metaReducers: MetaReducer<State>[] = !environment.production ? [] : [];
export const selectRouter = createFeatureSelector<
State,
fromRouter.RouterReducerState<any>
>('router');
const {
selectQueryParams, // select the current route query params
selectQueryParam, // factory function to select a query param
selectRouteParams, // select the current route params
selectRouteParam, // factory function to select a route param
selectRouteData, // select the current route data
selectUrl, // select the current url
} = fromRouter.getSelectors(selectRouter);
export const selectRouteId = selectRouteParam('id');
export const selectStatus = selectQueryParam('status');
// Drawer
export const selectDrawerNavigationItems = (state: State) => state.drawerNavigationItems.items as NavigationItem[];
/* src/app/reducers/index.ts */
import * as fromCat from './cat.reducer';
import { Owner } from '~/app/models'
export const ownerSelectors = new EntitySelectorsFactory().create<Owner>('Owner');
export interface State {
cat: fromCat.State;
}
export const reducers: ActionReducerMap<State> = {
cat: fromCat.reducer
};
export const selectCatState = (state: State) => state.cat;
export const {
selectAll: selectAllCats
} = fromCat.adapter.getSelectors(selectCatState);
export const selectedCatsWithOwners = createSelector(
selectAllCats,
ownerSelectors.selectEntities,
(cats, ownerEntities) => cats.map(c => ({
...c,
owner: ownerEntities[c.owner]
}))
);
import {
Action,
ActionReducer,
ActionReducerMap,
createFeatureSelector,
createSelector,
MetaReducer
} from '@ngrx/store';
import {environment} from '../../environments/environment';
import * as fromRouter from '@ngrx/router-store';
import * as fromDrawer from './drawer';
import {InjectionToken} from '@angular/core';
import {NavigationItem} from '../models/navigation-item';
import {EntitySelectorsFactory} from '@ngrx/data';
import {Community} from '../models/community';
export interface State {
router: fromRouter.RouterReducerState<any>;
drawerNavigationItems: fromDrawer.State;
}
export const ROOT_REDUCERS = new InjectionToken<ActionReducerMap<State, Action>>('Root reducers token', {factory: () => ({
router: fromRouter.routerReducer,
drawerNavigationItems: fromDrawer.reducer,
}),
});
export const metaReducers: MetaReducer<State>[] = !environment.production ? [] : [];
export const selectRouter = createFeatureSelector<
State,
fromRouter.RouterReducerState<any>
>('router');
const {
selectQueryParams, // select the current route query params
selectQueryParam, // factory function to select a query param
selectRouteParams, // select the current route params
selectRouteParam, // factory function to select a route param
selectRouteData, // select the current route data
selectUrl, // select the current url
} = fromRouter.getSelectors(selectRouter);
export const selectRouteId = selectRouteParam('id');
// export const selectStatus = selectQueryParam('status');
// Data
export const communitySelectors = new EntitySelectorsFactory().create<Community>('Community');
export const selectCommunityByRouteId = createSelector(
selectRouteId,
communitySelectors.selectEntities,
(id, communities) => communities.find(c => c.id === id)
);
// Drawer
export const selectDrawerNavigationItems = (state: State) => state.drawerNavigationItems.items as NavigationItem[];
export const communitySelectors = new EntitySelectorsFactory().create<Community>('Community');
export const selectCommunityByRouteId = createSelector(
selectRouteId,
communitySelectors.selectEntities,
(id, communities) => communities.find(c => c.id === id)
);
export class OneCommunityComponent implements OnInit {
community$: Observable<Community>;
constructor(
private store: Store<State>,
) {
this.community$ = this.store.select(selectCommunityByRouteId);
}
}