reactjs - MUI 弹出框没有正确锚定(AnchorEl、React、material-table、MUI)

标签 reactjs material-ui popover material-table

我已经查看了许多关于弹出框 anchor 定的问题,但是在使用 Material 表库中的 MaterialTable 元素时我没有看到任何问题:https://github.com/mbrn/material-table .

在调试时,它看起来像 anchorEl 正确地保存了按钮引用,但它似乎第二次重新渲染并丢失了引用。据我所知,这是来自重新安装的按钮。所以最终的渲染默认把popover放在屏幕的左上角。我想知道是否有人找到了一种方法来防止这种重新安装或其他一些解决方法。

export class UsersList extends Component {
constructor(props) {
super(props);
this.state = {
  anchorEl: null,
  anchorReference: "anchorEl"
};
}



render() {
const { classes } = this.props;
var { anchorEl } = this.state;
const open = Boolean(anchorEl);
return (
  <MaterialTable
    isLoading={this.state.isLoading}
    columns={[
      { title: "Username", field: "username" },
      ...more columns
    ]}
    data={this.state.users}
    onRowClick={(evt, selectedRow) => this.setState({ selectedRow })}


    //where I update my anchorEl on a click on the "edit" icon
    actions={[
      {
        icon: "edit",
        tooltip: "Edit",
        onClick: (event, rowData) => {
            this.setState({ anchorEl: event.currentTarget });
          }
        },
      },
    ]}

    components={{
      Body: props => (
        <React.Fragment>
          <MTableBody {...props} />
          <Popover
                //a breakpoint here is hit twice. First time with valid ref, second time without ref
                getContentAnchorEl={null}
                id="myId"
                open={open}
                onClose={this.handlePopoverClose.bind(this)}
                anchorEl={anchorEl}
                getContentAnchorEl={null}
                anchorOrigin={{ vertical: "bottom", horizontal: "center" }}
                transformOrigin={{ vertical: "top", horizontal: "center" }}
                open={open}
              >
                <Typography>The content of the Popover.</Typography>
              </Popover>

EDIT** 代码和框运行示例:如果您单击编辑列行项目,则会在屏幕左上角而不是行项目旁边显示一个弹出窗口:https://codesandbox.io/s/loving-tdd-8r910?file=/src/App.js

最佳答案

将 popover 移动到单独的组件,以便 anchorEl 与 Popover 位于同一组件中。菜单示例:

function MenuCell() {
  const [anchorEl, setAnchorEl] = useState(null);

  return (
    <div>
      <IconButton
        aria-label="more"
        aria-haspopup="true"
        onClick={(event) => setAnchorEl(event.currentTarget)}
      >
        <MoreVertIcon />
      </IconButton>
      <Menu
        anchorEl={anchorEl}
        keepMounted
        open={Boolean(anchorEl)}
        onClose={() => setAnchorEl(null)}
      >
        <MenuItem selected={false} onClick={() => setAnchorEl(null)}>
          Item 1
        </MenuItem>
        <MenuItem selected={false} onClick={() => setAnchorEl(null)}>
          Item 2
        </MenuItem>
        <MenuItem selected={false} onClick={() => setAnchorEl(null)}>
          Item 3
        </MenuItem>
      </Menu>
    </div>
  )
}
并在列单元格定义中使用:
function CustomTable() {
  
  const menuColumn = {
    id: 'menus',
    Header: '',
    Cell: ({ row }) => <MenuCell row={row} />,
  };

  // ...
}

关于reactjs - MUI 弹出框没有正确锚定(AnchorEl、React、material-table、MUI),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61467035/

相关文章:

javascript - 悬停时激活 Popover 并单击任意位置关闭

ios - 使用 UIPopoverPresentationController 在 iPhone 上的 Popover 演示

reactjs - 在引擎盖下 React Virtual Dom

javascript - 状态未使用 Redux 更新

xcode - 如何使用NSPopover制作菜单栏应用程序?

javascript - ReactJS - 使用 onBlur 验证电子邮件字段

javascript - 您可以将 Material-UI Link 与 react-router-dom Link 一起使用吗?

node.js - 你可以使用 react 服务器将你的请求转发到后端吗?

reactjs - Jest : test suite failed to run Error: No message was provided

reactjs - Material-ui 对 React 15.4.0 中重大变化的响应? "Cannot resolve module ' react /lib/EventPluginHub'"