使用 antd 在组件中创建子菜单失败

IT技术 reactjs antd
2021-05-25 19:12:42

我正在使用 antd:^3.5.4

我有一个包含用户管理项目的菜单。未登录时,菜单有一个带有登录页面链接的 menuItem 登录后,菜单有一个子菜单,其中包含多个链接,包括注销

我只是对连接的用户进行简单测试以显示链接或子菜单。当所有文件都在同一个文件中时,我工作得很好

    <Menu mode="horizontal">
      <Menu.Item key="home">
        <Link to={RoutesNames.HOMEPAGE}>Home</Link>
      </Menu.Item>
      {this.props.currentUserIsSignedIn ? ( 
      <SubMenu key="usermenu" title={<Avatar>A</Avatar>}> 
        <Menu.Item key="info">{this.props.currentUserEmail}</Menu.Item> 
        <Menu.Item key="logout"> 
          <Link onClick={this.props.signOutUser}>Log out</Link> 
        </Menu.Item> 
      </SubMenu> 
      ) : ( 
      <Menu.Item key="login"> 
        <Link to={RoutesNames.LOGIN}>Signin / Register</Link> 
      </Menu.Item> 
      )} 
    </Menu>

当我尝试创建一个处理此逻辑的组件 UserMenu 时,问题就开始了。最后我想要的是

    <Menu mode="horizontal">
      <Menu.Item key="home">
        <Link to={RoutesNames.HOMEPAGE}>Home</Link>
      </Menu.Item>
      <UserMenu user={this.props.currentUser}/>
    </Menu>

我创建了我的子组件 UserMenu。

首先我有这个错误:

    Uncaught TypeError: Cannot read property 'isRootMenu' of undefined
at ProxyComponent.render (SubMenu.js:274)

所以我更新了我的 UserMenu 组件来定义 parentMenu

   <SubMenu parentMenu={this.props.menu}

并在我的头文件中将父项设置为 parentMenu

   <Menu
     mode="horizontal"
     ref={el => this.menu = el}
   >
     <UserMenu menu={this.menu} user={this.props.currentUser} />
   </Menu>

使用此菜单props显示子菜单,但当鼠标悬停和鼠标移出子菜单时仍然出现错误

    Uncaught TypeError: onItemHover is not a function
at onTitleMouseEnter (SubMenu.js:454)

对于这个,我完全不知道该怎么做。

谢谢你的帮助

1个回答

菜单将额外的props传递给它的孩子。您需要确保这些props从您的 UserMenu 组件传递到您渲染的 SubMenu 组件。您可以使用对象扩展运算符执行此操作。例子:

const UserMenu = (props) => {
     const {username, customProp, ...other} = props;

     return <SubMenu {...other}>
          This is my {customProp} for {username}
     </SubMenu>
}