reactjs - Reactjs - 抽屉覆盖页面内容

标签 reactjs material-ui

我决定从material-ui库中将Drawer组件实现到我的react项目中,如下所示:

class RightDrawer extends React.Component {
  state = {
    open: false,
  };

  handleDrawerOpen = () => {
    this.setState({ open: true });
  };

  handleDrawerClose = () => {
    this.setState({ open: false });
  };

  render() {
    const { classes, children, theme } = this.props;

    return (
      <div className={classes.root}>
        <AppBar
          position="absolute"
          className={classNames(classes.appBar, this.state.open && classes.appBarShift)}
        >
          <Toolbar disableGutters={!this.state.open}>
            <IconButton
              color="inherit"
              aria-label="Open drawer"
              onClick={this.handleDrawerOpen}
              className={classNames(classes.menuButton, this.state.open && classes.hide)}
            >
              <MenuIcon />
            </IconButton>
            <Typography variant="title" color="inherit" noWrap>
              Mini variant drawer
            </Typography>
          </Toolbar>
        </AppBar>
        <Drawer
          variant="permanent"
          classes={{
            paper: classNames(classes.drawerPaper, !this.state.open && classes.drawerPaperClose),
          }}
          open={this.state.open}
        >
          <div className={classes.toolbar}>
            <IconButton onClick={this.handleDrawerClose}>
              {theme.direction === 'rtl' ? <ChevronRightIcon /> : <ChevronLeftIcon />}
            </IconButton>
          </div>
          <Divider />

            <List>{mailFolderListItems}</List>
        </Drawer>
        <main className={classes.content}>
          <div className={classes.toolbar} />
          {children}
        </main>
      </div>
    );
  }
}

RightDrawer.propTypes = {
  classes: PropTypes.object.isRequired,
  theme: PropTypes.object.isRequired,
};

export default withStyles(styles, { withTheme: true })(RightDrawer);

因此,我将所有组件包装在 RightDrawer 组件中,然后通过 {children} 注入(inject)它们。 最终结果是: enter image description here

因此它被裁剪为页面的 1/3,当表格填满时: enter image description here

我应该将 Drawer 直接插入到 App.js 中,而不是将每个组件都包装在里面吗?也许是由 className={classes.root} 引起的?

最佳答案

您提供的问题描述和代码不足以回答此问题。 正如我到目前为止所发现的,如果您想要一个全高抽屉,您可以将 height 添加到您的根类中。 例如:

root: {
    height: '100vh',
}

关于reactjs - Reactjs - 抽屉覆盖页面内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51849878/

相关文章:

javascript - 如何在 Material UI React 中以特定宽度(如 'sm')添加 fullWidth 等 Prop

reactjs - 在 Material Ui Datagrid 中更新行后不显示数据

reactjs - 从客户端访问Elasticsearch而不通过API服务器是否安全?

css - Material-UI 内联样式 SEO 影响

reactjs - Material-UI:提供的值 `undefined` 无效

reactjs - 视口(viewport)中的中心弹出框

javascript - 为什么 React 状态没有正确更新?

javascript - Ant 设计错误 : "Form.create() getFieldDecorator is not a function"

javascript - 如何动态地将添加的输入值推送到数组?

javascript - 如何在服务器端 React 中访问 JSX 组件的 DOM 事件处理程序