反应:警告:道具类型失败:无法读取未定义的 属性 'apply'

React : Warning: Failed prop type: Cannot read property 'apply' of undefined

我正在使用 React 中的导航栏工作,但一直收到此错误,而且我还没有找到可行的解决方案。这是我的代码片段。我正在尝试使用 react prop-types 库通过 link 或下拉菜单来验证我的导航栏道具。下面是我写的一段代码。

NavBar.js

const NavBar = ({ navItems }) => {
return (
    <nav role="navigation" className={styles.navBar}>
        <Logo type="text">
            ABCD
        </Logo>
        <div className={[styles.collapse, styles.noCollapse].join(' ')}>
            <SearchBox />
            <NavItems navItemsData={navItems} />
        </div>
    </nav>
);
};

NavItems.js

const NavItems = ({ navItemsData }) => {
return (
    <ul className={styles.navItems}>
        {navItemsData.map(navItemData => {
            let navItem = <NavItem {...navItemData} key={navItemData.id} />
            if (navItemData.type === 'dropdown') {
                navItem = <NavDropDownItem {...navItemData} key={navItemData.id} />
            }
            return navItem;
        })}
    </ul>
);
};

PropTypes 检查器(与 NavItems 在同一文件中):-

NavItems.propTypes = {
navItemsData: PropTypes.arrayOf(PropTypes.shape({
    id : PropTypes.number,
    type: PropTypes.oneOf(['link', 'dropdown']).isRequired,
    linkText: requiredIf(PropTypes.string.isRequired, props => props.type === 'link'),
    title : requiredIf(PropTypes.string.isRequired, props => props.type === 'dropdown'),
    dropDownList: requiredIf(PropTypes.arrayOf(PropTypes.shape({ linkText: PropTypes.string.isRequired })), props => props.type === 'dropdown')
}))
};

我不断在控制台中收到此警告。如下:-

Warning: Failed prop type: Cannot read property 'apply' of undefined
    in NavItems (at NavBar.js:15)
    in NavBar (at App.js:35)
    in div (at App.js:34)
    in App (at src/index.js:7)

我传递的道具:

const navItems = [{
    id : 1,
    type : 'link',
    linkText : 'Link1'
  },{
    id : 2,
    type : 'link',
    linkText : 'Link2'
  }, {
    id : 3,
    type : 'link',
    linkText : 'Link3'
  }, {
    id : 4,
    type : 'link',
    linkText : 'Link4'
  },{
    id : 5,
    type : 'link',
    linkText : 'Link5'
  },{
    id : 6,
    type : 'dropdown',
    dropDownList : [{
      linkText : 'LinkText'
    }]
  }]

如有任何帮助,我们将不胜感激。

当您使用 requiredIf 时,第一个参数应该是预期的类型。但它不应该有 isRequired 部分。例如,您的验证应如下所示。

NavItems.propTypes = {
    navItemsData: PropTypes.arrayOf(PropTypes.shape({
      id : PropTypes.number,
      type: PropTypes.oneOf(['link', 'dropdown']).isRequired,
      linkText: requiredIf(PropTypes.string, props => props.type === 'link'),
      title : requiredIf(PropTypes.string, props => props.type === 'dropdown'),
      dropDownList: requiredIf(PropTypes.arrayOf(PropTypes.shape({ linkText: PropTypes.string.isRequired })), props => props.type === 'dropdown')
}))};

不需要在 requiredIf 中执行 PropTypes.string.isRequired,因为它已经涵盖了所需的情况。

NavItems.propTypes = {
  navItemsData: PropTypes.arrayOf(
    PropTypes.shape({
      id: PropTypes.number,
      type: PropTypes.oneOf(["link", "dropdown"]).isRequired,
      linkText: requiredIf(PropTypes.string, props => props.type === "link"),
      title: requiredIf(PropTypes.string, props => props.type === "dropdown"),
      dropDownList: requiredIf(
        PropTypes.arrayOf(PropTypes.shape({ linkText: PropTypes.string })),
        props => props.type === "dropdown"
      )
    })
  )
};