gpt4 book ai didi

javascript - React Material-UI 状态未更新

转载 作者:行者123 更新时间:2023-11-28 05:50:58 25 4
gpt4 key购买 nike

我是 React 新手,正在尝试使用 Material UI 构建一个带有抽屉的简单 AppBar。

应用栏和抽屉似乎已正确实现,但由于某种原因,单击切换按钮时抽屉状态未更新。

我遵循了material-ui和React中的引用资料,所以我不确定发生了什么。这是该组件的代码:

  import React, { Component } from 'react'
import { Link } from 'react-router'
import AppBar from 'material-ui/AppBar';
import Drawer from 'material-ui/Drawer';
import MenuItem from 'material-ui/MenuItem';



class Appbar extends Component {

constructor(props) {
super(props);
this.state = {open: false};
}

handleToggle () {
this.setState({open: !this.state.open});
}

render() {
return (
<div>
<AppBar
title="Polism"
onLeftIconButtonTouchTap={this.handleToggle}
/>
<Drawer open={this.state.open}>
<MenuItem>Menu Item</MenuItem>
<MenuItem>Menu Item </MenuItem>
</Drawer>
</div>
)
}

}

export default Appbar

任何帮助将不胜感激!

最佳答案

为了使状态正确呈现,您所需要做的就是将函数绑定(bind)到上下文。由于您使用的是 ES6 脚本,因此您可以通过三种方式来实现这一点。

1) 使用箭头函数

handleToggle = ()  => {
this.setState({open: !this.state.open});
}

2).在构造函数中指定绑定(bind)

constructor(props) {
super(props);
this.state = {open: false};
this.handleToggle = this.handleToggle.bind(this);
}

3)调用函数时绑定(bind)

render() {
return (
<div>
<AppBar
title="Polism"
onLeftIconButtonTouchTap={this.handleToggle.bind(this)}
/>
<Drawer open={this.state.open}>
<MenuItem>Menu Item</MenuItem>
<MenuItem>Menu Item </MenuItem>
</Drawer>
</div>
)
}

我认为这可以解决您的问题。

关于javascript - React Material-UI 状态未更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38083871/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com