已棄用:不再支援具有 props 的選擇器
P粉786800174
P粉786800174 2024-02-21 20:05:20
0
1
435

在第二行,我收到此錯誤:不建議使用帶有 props 的選擇器。

const getUserProfileState = createFeatureSelector<UserProfileState>(authorizationFeatureKey);

const hasPermission = createSelector(
    getUserProfileState,
    (state: UserProfileState, permission: GQLPermission): boolean => {
        const result =
            state.permissions &&
            state.permissions.some((p) => p && p.resource === permission.resource && p.action === permission.action);
        return !!result;
    }
);

const hasCreateCasePermission = createSelector(getUserProfileState, (state: UserProfileState): boolean =>
    hasPermission.projector(state, {
        resource: PermissionResource.case,
        action: PermissionAction.create,
    })
);

我正在嘗試重構「hasPermission」函數,如下所示:

const hasPermission = (permission: GQLPermission) => createSelector(
    getUserProfileState,
    (state: UserProfileState): boolean => {
        const result =
            state.permissions &&
            state.permissions.some((p) => p && p.resource === permission.resource && p.action === permission.action);
        return !!result;
    }
);

但是我在如何基於這個 hasCreateCasePermission 進行重構方面遇到了困難。

P粉786800174
P粉786800174

全部回覆(1)
P粉465287592

附註:第一個範例中使用 .projector 有點味道。 您可以執行以下操作:

const hasCreateCasePermission = hasPermission({
        resource: PermissionResource.case,
        action: PermissionAction.create,
});
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板