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)
我的版本:
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)
现在可以了。
| 归档时间: |
|
| 查看次数: |
9100 次 |
| 最近记录: |