Skip to content

封装 Menu 子组件时导致的 key 不能正常传递的坑 #833

@lvboda

Description

@lvboda

这段代码中无论是 custom-sub-menu 还是 custom-sub-menu-inside 都没能正确的传给 Menu.SubMenu 组件,导致不能正常工作:

function CustomSubMenu(props) {
  return (
    <Menu.SubMenu key="custom-sub-menu-inside" title={<div>title</div>}>
      <Menu.Item key="item">item</Menu.Item>
    </Menu.SubMenu>
  );
}

<Menu mode="inline">
  <CustomSubMenu key="custom-sub-menu" />
</Menu>

我查了相关文档也没有找到类似问题,后面我读了源码才看到是在 https://github.com/react-component/menu/blob/master/src/utils/commonUtil.ts#L4 parseChildren 里通过 cloneElement 的方式注入了 props.eventKey 去传递的,而这个 eventKey 也没有声明在 SubMenuProps 类型里,上面的代码修复后应该是:

function CustomSubMenu(props) {
  return (
    <Menu.SubMenu eventKey="custom-sub-menu-inside" title={<div>title</div>}>
      <Menu.Item key="item">item</Menu.Item>
    </Menu.SubMenu>
  );
}

<Menu mode="inline">
  <CustomSubMenu key="custom-sub-menu" />
</Menu>

尽管现在 antdv6 已经弃用 children 但是如果有直接使用 rc-component/menu 或者老版本 antd 项目中依然可能出现此类问题,这里我提交一个 issue 希望可以给后面遇到同样问题的人解惑。

同时我对 https://github.com/react-component/menu/blob/master/src/utils/commonUtil.ts#L4 这里的实现表示不解,能否用更好的方式 refactor(比如 Context)。

Image

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions