首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >createSelector函数可以获取直到9个参数

createSelector函数可以获取直到9个参数
EN

Stack Overflow用户
提问于 2019-07-02 18:30:22
回答 1查看 827关注 0票数 3

我创建了一个新选择器:

代码语言:javascript
运行
复制
const getInquiryBasicInfo = createSelector(
getMedia(getInquiryRelatedEntities, ConnectionTypes.InquiryMedia.name),
getJournalist(getInquiryRelatedEntities, ConnectionTypes.InquiryReporter.name),
getReceiveDate,
getResponsDate,
getMediaOutlet,
getInitiatedCount(getInquiryDetails),
getNumberOfPublication(getInquiryDetails),
getPrecedent(getInquiryDetails),
getMinRoleTitle(getInquiryDetails),
getLanguage,
(media, journalist ,receiveDate, responsDate, mediaOutlet, initiatedCount, numberOfPublication ,isPrecedent,role, languages) => {
    return [media,journalist,receiveDate, responsDate, mediaOutlet, initiatedCount,numberOfPublication,isPrecedent ,role, languages].filter(info => {
        return info.value.length;
    });
}

);

我得到了这个错误:

代码语言:javascript
运行
复制
 error TS2554: Expected 2-9 arguments, but got 11.

如何使用9个以上参数的createSelector函数?我使用angular 8,我使用:{createSelector } from '@ngrx/store';

谢谢你的帮助!

EN

回答 1

Stack Overflow用户

发布于 2019-07-02 19:50:45

根据我的理解,它应该后退到一个允许所有选择器的后备选择器:

代码语言:javascript
运行
复制
export function createSelector(
  ...input: any[]
): MemoizedSelector<any, any> | MemoizedSelectorWithProps<any, any, any> {
  return createSelectorFactory(defaultMemoize)(...input);
}

也就是说,拥有如此大的选择器通常是一种糟糕的做法,您应该将它们拆分成多个较小的选择器。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/56850465

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档