【发布时间】:2021-06-24 18:53:08
【问题描述】:
我是 React 前端开发的新手。我正在尝试向我的 Material-UI NavBar 添加一个临时抽屉。我在代码中添加了一个抽屉:
class Navbar extends Component {
render() {
const { authenticated } = this.props;
const [open, setOpen] = useState(false);
const handleDrawer = () =>{
setOpen(true)
}
return (
<AppBar position="fixed">
<Toolbar className="nav-container">
{authenticated ? (
<Fragment>
<IconButton edge="start" onClick={handleDrawer} >
<Menu/>
</IconButton>
<Drawer
anchor='left'
open={open}
onClose={()=> setOpen(false)}
>
<h3> Drawer</h3>
</Drawer>
<NewPost/>
<Link to="/">
<MyButton tip="Home">
<HomeIcon color = "disabled"/>
</MyButton>
</Link>
<Link to="/chats">
<MyButton tip="Chats">
<ChatIcon color = "disabled"/>
</MyButton>
</Link>
<Notifications />
</Fragment>
):(
<Fragment>
<Button color="inherit" component={Link} to="/login">Login</Button>
<Button color="inherit" component={Link} to="/signup">Singup</Button>
<Button color="inherit" component={Link} to="/">Home</Button>
{/* <Button color="inherit" component={Link} to="/user">Profile</Button>*/}
</Fragment>
)}
</Toolbar>
</AppBar>
)
}
}
Navbar.propTypes = {
authenticated: PropTypes.bool.isRequired
}
const mapStateToProps = state =>({
authenticated: state.user.authenticated
})
export default connect(mapStateToProps)(Navbar)
但是出现了这个错误:
React Hook "useState" cannot be called in a class component. React Hooks must be called in a React function component or a custom React Hook function
所以,我创建了一个构造函数来处理这个(在渲染之前):
constructor(props) {
super(props);
this.state = {
open: false
};
}
当我想改变状态时,我使用了:
this.setState({ open: true })
但是,当我触发抽屉(单击按钮)时,它并没有打开。我能做什么?
【问题讨论】:
-
试试
open={this.state.open}而不是open={open}。 -
或者
const { open } = this.state;在渲染方法的顶部,所以open={open}可以工作。
标签: javascript reactjs material-ui