material-ui Drawer - findDOMNode is deprecated in StrictMode

后端 未结 4 793
广开言路
广开言路 2020-12-30 18:48

I have a simple ReactJS app based on hooks (no classes) using StrictMode.

I am using React version 16.13.1 and Material-UI version 4.9.10.

In the Appbar I a

相关标签:
4条回答
  • 2020-12-30 19:00

    Yeah it's annoying. Material UI's team is not keeping up with the React devs. For now, just remove the Strict mode tag. It's unfortunately what happens with cutting edge technologies.

    0 讨论(0)
  • 2020-12-30 19:04

    This is a StrictMode Warning

    Strict mode checks are run in development mode only; they do not impact the production build.

    ReactDOM.render(
      <React.StrictMode>
        <App />
      </React.StrictMode>,
      document.getElementById('root')
    );
    

    to

    ReactDOM.render(
        <App />,
      document.getElementById('root')
    );
    
    0 讨论(0)
  • 2020-12-30 19:17

    According to Material-ui changelog, it should be solve in V5, which is still in alpha.

    It seems that at least in some cases this issue cause by createMuiTheme. You can solve this issue by using the experimental (unstable) theme creator

    If you want to get the experimental theme creator instead of removing React.StrictMode, you can change it's import from:

    import { createMuiTheme } from '@material-ui/core';
    
    

    To

    import { unstable_createMuiStrictModeTheme as createMuiTheme } from '@material-ui/core';
    
    
    0 讨论(0)
  • 2020-12-30 19:27

    Have you tried using React.forwardRef? [MUI docs] [React docs]

    const PersistentDrawer = React.forwardRef(
      (props, ref) => (
        <Drawer
          variant="persistent"
          anchor="left"
          open={props.open}
          ref={ref}
        />
      )
    )
    
    return (
      <div className={classes.root}>
        <AppBar position="static">
          <Toolbar>
            <IconButton
              aria-label="menu"
              className={classes.menuButton}
              color="inherit"
              edge="start"
              onClick={handleDrawerOpen}
            >
              <MenuIcon />
            </IconButton>
            <Typography variant="h6" className={classes.title}>
              Online Information
            </Typography>
          </Toolbar>
        </AppBar>
        <PersistentDrawer open={open} />
      </div>
    )
    
    0 讨论(0)
提交回复
热议问题