-
-
Notifications
You must be signed in to change notification settings - Fork 262
Open
Description
这段代码中无论是 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)。

Metadata
Metadata
Assignees
Labels
No labels