自定义组件上的 OverlayTrigger 不起作用

Sim*_*ult 10 reactjs react-bootstrap

我试图在自定义组件(按钮)悬停时显示弹出窗口:

class MyComponent extends React.PureComponent<MyComponentProperties>  {
    public render(): JSX.Element {
        const overlay: JSX.Element = (
            <Popover id={this.uuid}>
                <Popover.Content>
                    Hello world!
                </Popover.Content>
            </Popover>
        );

        return <OverlayTrigger trigger="hover" placement="auto" delay={{show : 700, hide : 0}} overlay={overlay}>
            <MyFancyButton ... />
        </OverlayTrigger >
    }
}
Run Code Online (Sandbox Code Playgroud)
class MyFancyButton extends React.PureComponent<MyFancyButtonProperties> {
    public render(): JSX.Element {
        return <button ...>Hover me!</button>
    }
}
Run Code Online (Sandbox Code Playgroud)

弹出窗口不显示。render但是,如果我将函数的返回更改MyComponent为:

return <OverlayTrigger trigger="hover" placement="auto" delay={{show : 700, hide : 0}} overlay={overlay}>
    <button>Hover me!</button>
</OverlayTrigger >
Run Code Online (Sandbox Code Playgroud)

我检查了https://react-bootstrap.github.io/components/overlays/#overlay-trigger,它说:

请注意,触发组件必须能够接受引用,因为将尝试添加引用。您可以将forwardRef() 用于函数组件。

我不知道该怎么做。我尝试添加一个ref属性MyFancyButtonProperties并将其转发到button,但它不起作用:

class MyFancyButton extends React.PureComponent<MyFancyButtonProperties> {
    public render(): JSX.Element {
        return <button ref={this.props.ref} ...>Hover me!</button>
    }
}
Run Code Online (Sandbox Code Playgroud)

我的版本:

  • 反应16.8.6
  • React 引导程序 1.0.0-beta.14

Sim*_*ult 21

我终于在这里找到了解决方案:https://github.com/react-bootstrap/react-bootstrap/issues/2208#issuecomment-301737531

我用to的函数包装了该组件,该组件应该获得工具<span>提示renderMyComponent

return <OverlayTrigger trigger="hover" placement="auto" delay={{show : 700, hide : 0}} overlay={overlay}>
    <span><MyFancyButton ... /></span>
</OverlayTrigger >
Run Code Online (Sandbox Code Playgroud)

现在可以了。

  • 这会破坏我的情况下的放置位置。 (4认同)