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

问题描述 投票:0回答:2

我正在React中的导航栏上工作,我一直收到此错误,但我还没有找到有效的解决方案。这是我的代码片段。我正在尝试使用react prop-types库来通过链接或下拉列表来验证我的navbar props。以下是我编写的代码。

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'
    }]
  }]

任何帮助将不胜感激。

javascript reactjs react-proptypes
2个回答
0
投票

使用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')
}))};

1
投票

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

Edit goofy-rain-6bx03

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"
      )
    })
  )
};
© www.soinside.com 2019 - 2024. All rights reserved.